Most of my clients require a running NAV Application Server. The NAS that is included in NAV 2009 R2 requires a license that is included in most licenses today. However, there are cases where more than one NAS is needed. That requires additional NAS licenses. Where the customer is running NAV 2009 R2 middle tier service this changes. By running a VB.NET NAV Application Server it is possible to setup multiple services on a single CAL license. The CAL license is not as expensive as the NAS license. Here is the solution that I offer.
First, I create a codeunit in NAV
[code htmlscript=”false”]ExecuteCodeunit(CodeunitID : Integer;Log : Boolean) Success : Boolean
IF Log THEN LogEntryNo := InsertLogEntry(5,CodeunitID);
Success := CODEUNIT.RUN(CodeunitID);
IF Log THEN
UpdateLogEntry(LogEntryNo,Success)
ELSE IF NOT Success THEN BEGIN
LogEntryNo := InsertLogEntry(5,CodeunitID);
UpdateLogEntry(LogEntryNo,Success)
END;
InsertLogEntry(ObjectType : ‘,,,Report,,Codeunit’;ObjectNo : Integer) : Integer
WITH JobQueueLogEntry DO BEGIN
INIT;
ID := CREATEGUID;
“User ID” := USERID;
“Start Date/Time” := CURRENTDATETIME;
“Object Type to Run” := ObjectType;
“Object ID to Run” := ObjectNo;
INSERT(TRUE);
COMMIT;
EXIT(“Entry No.”);
END;
UpdateLogEntry(LogEntryNo : Integer;WasSuccess : Boolean)
WITH JobQueueLogEntry DO BEGIN
GET(LogEntryNo);
“End Date/Time” := CURRENTDATETIME;
IF WasSuccess THEN
Status := Status::Success
ELSE BEGIN
Status := Status::Error;
SetErrorMessage(COPYSTR(GETLASTERRORTEXT,1,1000));
END;
MODIFY;
COMMIT;
END;[/code]
This codeunit uses the Job Queue Log to log the execution. Next step is to publish this codeunit as a web service in table no. 2000000076. Default web service name is NAVAppServer.
On the server you install the following files (in my case to C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server)
Next step is to edit the VB.NET NAV Application Server.exe.config file and customize the values.
<applicationSettings> <NAV_Application_Server.My.MySettings> <setting name="NAVAppServer" serializeAs="String"> <value>http://<Middle Tiere Host Name>:7047/DynamicsNAV/WS/<CompanyName>/Codeunit/NAVAppServer</value> </setting> <setting name="CodeunitID" serializeAs="String"> <value>81004</value> </setting> <setting name="LogMode" serializeAs="String"> <value>False</value> </setting> <setting name="TimerInterval" serializeAs="String"> <value>90000</value> </setting> <setting name="LogFrequency" serializeAs="String"> <value>15:00:00</value> </setting> <setting name="SMTPHost" serializeAs="String"> <value>mail.dynamics.is</value> </setting> <setting name="FromAddress" serializeAs="String"> <value>gunnar@dynamics.is</value> </setting> <setting name="ToAddress" serializeAs="String"> <value>gunnar@dynamics.is</value> </setting> <setting name="RetryTimerInterval" serializeAs="String"> <value>45000</value> </setting> </NAV_Application_Server.My.MySettings> </applicationSettings>
To install as a service start command prompt in elevated mode and execute installutil.exe command. The install will prompt for the user to start the service.
C:\Windows\Microsoft.NET\Framework\v2.0.50727>InstallUtil.exe "C:\Program Files(x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.exe" Microsoft (R) .NET Framework Installation utility Version 2.0.50727.5420 Copyright (c) Microsoft Corporation. All rights reserved. Running a transacted installation. Beginning the Install phase of the installation. See the contents of the log file for the C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.exe assembly's progress. The file is located at C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.InstallLog. Installing assembly 'C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.exe'. Affected parameters are: logtoconsole = assemblypath = C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.exe logfile = C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.InstallLog Installing service VB.NET-NAVAppServer$DEFAULT... Service VB.NET-NAVAppServer$DEFAULT has been successfully installed. Creating EventLog source VB.NET-NAVAppServer$DEFAULT in log Application... The Install phase completed successfully, and the Commit phase is beginning. See the contents of the log file for the C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.exe assembly's progress. The file is located at C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.InstallLog. Committing assembly 'C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.exe'. Affected parameters are: logtoconsole = assemblypath = C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.exe logfile = C:\Program Files (x86)\Dynamics.is\VB.NET NAV Application Server\VB.NET NAV Application Server.InstallLog The Commit phase completed successfully. The transacted install has completed.
The last step is to change the service startup and start the service.
The service will create entries in the Application Log.
The following ZIP files are encrypted.
Very elegant solution, Gunnar!
This will certainly save customers some headaches license-wise.
Great work 🙂
I love reading your technical posts on Dynamics NAV.
Keep up the great work 🙂
Very nice solution indeed.
Does this Application Server support the use of .NET Interop in the jobs that it runs?
Yes, it does support .NET interop.
Hi Gunnar, may i know the password for VB.NET NAV Application Server DEFAULT Executables file please
Hi
You can pick this up from http://objects4nav.com/vb-net-nav-application-server-for-nav-2009-r2/
Hi Gunnar,
I’ve just purchased your product and set it up but I’m getting the issue ‘Execution of codeunit 81004 failed’. Also I get an email advising ‘the remote name could not be resolved: ‘skyrr-sql-kro-1’. It seems to still want to use the web service in the original config file you provided.
I have updated the config file with the appropriate web service URL and also ensured we do have access in our license to run the codeunits.
Can you please assist.
Sending the source code to you via email.
Hi Gunnar,
Have you sent through the source code as I have not received it.
Drop me an email,þI will reply
Hi Gunnar,
I’ve just purchased your programm and I’m having the same issue as David.
Is it possible to get the Source Code?
Sure, in you mailbox