解决asp.net mvc首次启动速度慢的问题记录IIS性能优化
事情是这样的,做好一个ASP.NET MVC网站之后,首次启动速度非常慢,要几秒到几十秒不等的时间才能展现页面.每隔几十分钟就会出现一次这样的情况.问题发现了,下面开始解决.
首先
开发环境是:VS2013+IIS8+SQLExpress
部署环境是:WIN2008R2+IIS7.5+SQL
在谷歌百度一下之后,看到有人说ASP.NET网站发布的时候需要预编译.这样不但能解决首次速度慢的问题,还能把cshtml的内容编译.这样别人就看不到我们VIEW的代码了.那么打开VS.
发布的时候把"在发布期间预编译"打钩,点击后面的设置取消选择"允许更新预编译站点".这样编译出来的网站view被编译成.compiled文件.并且根目录下多了一个PrecompiledApp.config文件.
部署到服务器上之后,问题依旧
那么继续谷歌百度一下,看到另一个结局反感是优化IIS.这也是上面要介绍部署环境的原因.因为IIS7.5和IIS8有个很大的区别关于性能.如果部署在IIS8上的话,只需要简单的设置即可.下面是设置方法:
IIS8设置
应用程序池-高级设置-启动模式:AlwaysRunning
应用程序池-高级设置-进程模型-闲置超时:1740 (分钟)
应用程序-高级设置-常规-预加载已启用:True
这样就可以解决问题了.
但是在IIS7.5上并没有这些选项,需要安装一个模块:Application Initialization Module for IIS 7.5
下载安装略过不提.主要记录一下配置方法.
打开服务器上的ApplicationHost.config文件.这个文件在IIS的安装目录Config下.
添加如下内容(但是似乎不添加也行)
< globalModules >
< add name = "ApplicationInitializationModule"
image = "%windir%\System32\inetsrv\warmup.dll" />
</ globalModules >
|
然后设置网站应用程序和和对应的应用程序池
< system.applicationHost >
< applicationPools >
< add name = "West Wind West Wind Web Connection"
autoStart = "true"
startMode = "AlwaysRunning"
managedRuntimeVersion = "v4.0"
managedPipelineMode = "Integrated" >
< processModel identityType = "LocalSystem"
setProfileEnvironment = "true" />
</ add >
</ applicationPools >
< sites >
< site name = "Default Web Site" id = "1" >
< application path = "/MPress.Workflow.WebQueueMessageManager"
applicationPool = "West Wind West Wind Web Connection"
preloadEnabled = "true" >
< virtualDirectory path = "/"
physicalPath = "C:\Clients\…" />
</ application >
</ site >
</ sites >
</ system.applicationHost >
|
关键在于应用程序池设置的autoStart="true" startMode="AlwaysRunning" 这两个的意思是自动自动和启动模式.
网站应用程序设置的preloadEnabled="true"
这样设置完成之后网站已经基本可以保证秒开了,基本解决了第一次打开速度很慢的问题.当然还遗留了一个EF首次加载缓慢的问题,额这还不知道怎么解决.似乎是没办法解决的.