使用IIS 6.0运营虚拟主机的朋友们都会碰到这样一个问题,当某个网站占用大量CPU资源时,会把整个服务器都拖慢了,影响服务器上其他网站的访问速度,客户们的投诉也让系统管理员倍感头疼。我们知道,从IIS 6.0开始,微软引入了应用程序池的概念,也就是把多个网站分组放置到不同的“池子”中。作为系统管理员,可以自由调整每个程序池中的网站,也可以随意把某个站点在各个进程池之间进行迁移。
图示:一个进程对应着一个应用程序池
传统解决方案
当某个站点消耗大量CPU时,其所在的应用程序池w3wp.exe的CPU值会随之飙升。在传统的IIS 6.0的环境下,我们只能先根据任务管理器中的PID值判断出是哪个应用程序池造成的,结束对应的w3wp进程,再停止该应用程序池。然后使用二分法,把该程序池中的网站分一半到其他程序池,再观察,等问题网站发作后再反复执行上述的操作。这个过程耗时耗力,要揪出目标网站可能需要几天甚至一周左右。那么新版的IIS 8.0是否能更完美的解决这个问题呢?
在揭晓答案前,作为系统管理员,我们可以想象下,微软对这个问题会采取哪些处理方案。我能想到的一些升级或改进方法有:
1、新版IIS可以针对每个网站设置CPU限制,对超出限制的网站自动关闭或其他处理。
2、新版IIS可以针对每个应用程序池设置CPU限制,对超出限制的程序池自动停止或其他处理。
3、由第三方软件公司开发针对IIS的插件,解决某个站点CPU过大就会影响整台服务器的问题。
不知道你还能想到其他解决方案吗?实际上,微软从IIS 7.0起就开发了CPU Throttlling(CPU扼喉)功能,基本采用了上面预想的方法2,可以事先对每个程序池进行CPU限制,未雨绸缪,一旦出现问题站点,最多只影响同在一个程序池的其他用户,而不会造成整机故障。到了IIS 8.0时代,这个功能变得更加细致,下面我就来剖析新版IIS 8.0的CPU限制策略。
最新解决方案
1、选择应用程序池操作面板上的“高级设置”。
2、秘密就在“CPU”栏目下的“限制(百分比)”和“限制操作”这两项。首先说明下第一项百分比,假如我们想限制这个程序池的CPU为10%,那么应该填写10000,即10*1000,这个地方要特别注意。
关于“限制(百分比)”这项,微软的官方解释是:限制(百分比)设置了应用程序池中的工作进程(即w3wp.exe)在“限制间隔“(默认5分钟)的时间段内使用CPU时间的最大百分比。如果超出这个限制,系统将记录到事件日志中,并且触发限制操作中的某个可选事件。
默认的限制(百分比)为0,表示不进行任何CPU限制,而不是把CPU限制为0。
3、接下来就是最关键的限制操作项了。这个项中有4种选择,分别阐述如下。
- NoAction:超出限制后,除了写入事件日志之外,不执行任何操作。
- KillW3WP:超出限制后,关闭应用程序池。我们不推荐使用此项,因为出现问题站点是无法预期的,如果贸然关闭,既无法进一步判断问题站点,也会造成网站无法打开,引起其他客户的抱怨。
- Throttle:将CPU严格限制为百分比中的数值。问题站点发作时,会影响同一程序池下的其他网站。
-
ThrottleUnderLoad:只有在系统CPU资源不足时,才开始限制CPU使用率。举例说明,假如当前系统CPU为10%,设置某程序池限制CPU为20%,问题站点占用CPU为30%。这时仍然不会限制CPU使用,因为总的CPU才40%,系统资源仍然绰绰有余。
我们推荐采用Throttle或ThrottleUnderLoad,根据经验,ASP或ASP.NET网站可以直接使用Throttle限制,某些PHP网站占用CPU较高,采用Throttle限制后网站打开速度不理想,这时可以采用ThrottleUnderLoad。
统一设置程序池
如果你不想逐个设置,可以直接设置应用程序池默认值。操作步骤很简单,先点击左侧菜单的“应用程序池”,再点击右边操作栏的“设置应用程序默认”,弹出的界面和单独程序池设置的界面是一样的。
要注意的是,这里的默认设置只影响以后新建的应用程序池,设置默认值之前建立的程序池不受影响,因此你可能要逐个设置下这些老家伙们。