日期:2008-07-03  浏览次数:21155 次

 

Aiyiweb.Com提示:IIS6以及IIS7对静态文件gzip紧缩方式的区别.

 

先说明下为什么要写这篇文章,以及纠结于这个“小问题”。首先开启静态文件的gzip紧缩非常有利用提高网站的访问速度,并且无效减少蜘蛛爬行静态页面的time-taken,同时也不会像开启动态文件紧缩一样可能会对百度蜘蛛形成200 0 64的抓取问题,所以一方面,网站速度快有利于提高用户体验,另一方面,google管理员博客在今年曾经明确表示网站速度是排名的要素之一,而对于拿国外主机做百度中文站优化,time-taken不理想会导致百度蜘蛛内页抓的少,国平之前在本人博客文章网页加载速度是如何影响SEO效果的中也提到过,在固定的一段时间内蜘蛛抓取网站的总时间是固定的,那么抓取速度上去了,抓取页面数就会更多,反之则少。

好吧,开始注释,在上篇文章《蜘蛛抓取静态页面与触发gzip紧缩的实验结果》中的问题二,我提出了gzip静态页面的紧缩版本在服务器上保存方式的猜测,在困惑了许久之后,发现导致两个主机前往gzip结果不同的最终缘由是iis版本而不是我猜测的缓存文件夹设置过小

理想上,iis7比iis6在静态紧缩上有了较大的更新,在IIS6中,静态紧缩是在一个不同的线程上进行的,所以在收到一个HTTP请求后,第一个发送给浏览器的HTML版本是没有紧缩过的,而同时IIS6会开始使用一个不同的线程对这个文件进行紧缩并且将这个紧缩后的版本长期保存在紧缩文件的缓存文件夹内。而在以前,也就是IIS6服务器上,在紧缩完成之后凡是对该被紧缩版本的静态文件的HTTP请求,IIS6都会直接从缓存文件夹中直接调用紧缩后的版本并前往给浏览器。

但是在IIS7中,紧缩是在主线程上进行的,而且为了节省紧缩的成本,IIS7不对所有的HTTP请求而只对哪些经常会被用户访问的静态文件进行紧缩版本的长期保存,这也就是为什么我在之前第一次访问没有紧缩,短期内再次访问前往的是紧缩版本,但是再过几分钟访问前往的又是未紧缩版本的缘由。这里我们可以理解为IIS7并没有将紧缩版本实际保存到缓存文件夹中,而是只在服务器内存中做了保存,或者是临时将紧缩版本保存到缓存文件夹中,一会之后进行删除。

而IIS7定义什么文件是经常访问的符合紧缩标准的方法是system.webServer/serverRuntime中的以下两个属性,frequentHitThreshold和frequentHitTimePeriod 。如果IIS在frequentHitTimePeriod时间段内接收到了对某个静态文件的超过frequentHitThreshold闸值次数的访问,那么IIS7就会像IIS6一样紧缩该静态文件并且将这个紧缩后的版本长期保存在紧缩文件的缓存文件夹内。如果用户访问网站某文件时,曾经在缓存文件夹中存在该文件的缓存版本,那么IIS7是不会再判断frequentHitThreshhold这个逻辑而是直接前往紧缩版本给浏览器。

这种设置的确很蛋疼,但是微软官方给出的答复是这样有利用提高服务器功用。。。那么如果想要让IIS7能够向IIS6一样做紧缩的话,有两种处理方法,当然都是修正frequentHitThreshold和frequentHitTimePeriod这两个值:

第一种是在web.config中添加以下内容,将frequentHitThreshold调至1,将frequentHitTimePeriod调制10分钟

<system.webServer>

<serverRuntime enabled="true"

frequentHitThreshold="1"

frequentHitTimePeriod="00:10:00"/>

</system.webServer>

第二种方法是打开%windir%\system32\inetsrv\appcmd.exe,然后再命令行界面中输入以下命令字符串,然后回车

set config -section:system.webServer/serverRuntime -frequentHitThreshold:1

微软官方建议比较不激进的办法是不要调低frequentHitThreshold而是提高frequentHitTimePeriod,这样对服务器功用更适中。这里要提到的是,对于拥有VPS的朋友们,建议可以手动设置,而虚拟主机用户能不能设置就得看服务商了,我就很悲剧的改不了。大家试试看吧