ASP.NET MVC - Slow initial load
Typically an application will always take a little extra time to load as the application domain starts up.
Things helping exacerbate this could be anything from poorly written code (IE: Application_Start) to certain libraries you may be using (ORMs for example). How many modules do you have loaded?
For starters check your web.config for the infamous <compilation debug="true">
. That can have significant performance ramifications in a production setup. Set it to "false"!
Recommend googling something along the lines of "improving application startup time" and looking for things that may relate to your particular application.
Update from your first comment:
If you're seeing the application start up again (hangs for a few seconds) after 30 minutes consistently this is likely related to your Application Pool Recycling settings in IIS.
Go into IIS Manager (this assumes v7+):
- Application Pools
- Right click the pool being used for your application(s)
- Select "Recycling", a window will come up labeled "Recycling Conditions"
- Inspect those settings since they will determine when to automatically kill your app pool and have it restart.
In terms of general performance you may want to try:
- Adding some debugging statements that spit out elapsed time in your Application_Start() method or any other applicable location to try to catch what's taking the longest.
- Create a completely clean demo project and deploy it. See if it suffers from the same problem. If it doesn't try introducing more and more of your real code until you detect a slowdown.
If you're really stumped #2 may be your best bet even though it will be probably be the slowest option.
I also had same problem, with slow first loading asp.net mvc sites, finally I found the best way for load a site, extremly fast in first load.
My solution is for windows server 2008 r2 and IIS 7.5, but in upper windows servers and upper iis versions also work, with some simple diferences.
First of all, you must set startMode of your application pool to always running, this will prevent your application pool from sleeping, after some time. (in my case just this step changes my sites first load from 45-55 seconds to about 8-12 seconds).
in step one, there is no first request for your website, for preloading your website, we need another step, that is by installing Application Initialization module for iis7.5 from here
in step two, you must set preloadEnabled=true for your website, this option is what application initialization added to site settings.
For more information and how you can set these option please refer to this blog post: http://blogs.iis.net/wadeh/application-initialization-part-2
after step two, my web site loads in just 1-3 seconds.