Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to properly autostart an asp.net application in IIS10

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:

  • Set the Application Pool to StartMode=AlwaysRunning
  • Set the site in question (that belongs to beforementioned Pool) to preloadEnabled=true
  • Install the Application Initialization feature to the Windows installation
  • Add the <applicationInitialization> node to the web.config's <system.webServer> node

The 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.

like image 821
Robba Avatar asked Jan 06 '16 13:01

Robba


People also ask

How do I automatically restart application Pool in IIS?

Open Internet Information Services (IIS) Manager. In the Connections pane, select the Application Pools node, revealing the Application Pools pane in the main view. Select the application pool for which you wish to enable Auto-Start. Locate the Start Mode option under the General group and set it to AlwaysRunning.

What is application initialization in IIS?

IIS Application Initialization allows website administrators to configure a web application to be pre-loaded as soon as the worker process starts, before the first request arrives. By pre-loading the application, the worker process is able to reduce the time it takes to respond to the first request.


1 Answers

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:

  1. Set the Application Pool to StartMode=AlwaysRunning to make sure the w3svc.exe process is always running for the App Pool.
  2. Set the site in question (that belongs to beforementioned Pool) to preloadEnabled=true
  3. Install the 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.

like image 83
Robba Avatar answered Sep 22 '22 16:09

Robba