I'm trying to get my ASP.NET application to automatically start whenever the application pool is running.
As per the lots and lots of references online I have already done the following:
StartMode=AlwaysRunning
preloadEnabled=true
Application Initialization
feature to the Windows installation<applicationInitialization>
node to the web.config's <system.webServer>
nodeThe web application is based on Owin and has a simple log4net logging statement in it's Startup.Configuration()
method. Now when restarting IIS I see that the w3svc.exe process is running, so I know the StartMode=AlwaysRunning
is working. There are however no logging messages in the log file.
Navigating to any url (even a nonexisting one) in the application will start the app and add the log line.
Because of the actual work that's done in the startup of the application I really want the application to truly preload, but I seem to be unable to get it done.
Searching this site I have unfortunately not been able to find a solution.
Thanks in advance.
To answer my own question for future generations, it seems I was on the right track. To get the application to start in IIS10 (and I assume in IIS 8 as well) you only need the following three steps:
StartMode=AlwaysRunning
to make sure the w3svc.exe process is always running for the App Pool.preloadEnabled=true
Application Initialization
feature to the Windows installation as per the instructions here.One important thing to note is that if the Application Initialization
task was not previously installed on the machine you must reboot the machine. This is what I missed the last time which led to quite some time wasted looking for other things :(
Anyway, setting up those three things will cause the app to actually go through it's initialization, which is especially useful if you want to setup some scheduling task (ea using the Quartz NuGet package).
Note by the way that if you setup auto initialization like above, the application will also automatically start after the shutdown timeout has expired and on application pool recycles.