在运行 Fiddler 时,我注意到向我的服务器请求静态 ~5MB XML 文件时有些奇怪:尽管发送了逐字节相同的标头(编辑:包括标头),但响应却不同:
响应 A:
1. 700KB 的 gzip 内容
2. 包括 Content-Length 标头
3. 排除的 Transfer-Encoding 标头
响应 B:
1. 1000KB 的 gzip 内容
2. 排除 Content-Length 标头
3. 包含 Transfer-Encoding 标头:分块标头
我该怎么做才能始终收到响应 A 中显示的带宽效率更高的行为?
原始请求:
GET http://[REDACTED]/[REDACTED]/[REDACTED]/[REDACTED].xml?dt=Test1 HTTP/1.1
Host: [REDACTED]
Connection: keep-alive
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.31 (KHTML, like Gecko) Chrome/26.0.1410.64 Safari/537.31
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
原始响应 A:
HTTP/1.1 200 OK
Content-Type: text/xml
Content-Encoding: gzip
Last-Modified: Tue, 07 May 2013 04:04:01 GMT
Accept-Ranges: bytes
ETag: "80ceefe7d74ace1:0"
Vary: Accept-Encoding
Server: Microsoft-IIS/7.5
X-Powered-By: ASP.NET
Date: Tue, 07 May 2013 21:07:21 GMT
Content-Length: 728105
[700KB GZipped Body]
原始响应 B:
HTTP/1.1 200 OK
Transfer-Encoding: chunked
Content-Type: text/xml
Content-Encoding: gzip
Last-Modified: Tue, 07 May 2013 04:04:01 GMT
Accept-Ranges: bytes
ETag: "60be30e8d74ace1:0"
Vary: Accept-Encoding
Server: Microsoft-IIS/7.5
X-Powered-By: ASP.NET
Date: Tue, 07 May 2013 21:07:14 GMT
[1MB Gzipped Body]
静态文件的压缩是动态处理的(如果启用了动态压缩),而 IIS 认为该文件不常用。一旦文件被认为是频繁的,它将被压缩和缓存(如果启用了静态压缩)。缓存的版本将继续提供,直到它再次变得不频繁为止。您可以在 IIS 中使用 2 个配置设置来配置常用文件:
system.webServer/服务器运行时:
frequentHitThreshold
:同一个文件应该被请求多少次,才被认为是频繁和缓存?默认为 2。frequentHitTimePeriod
:同一文件应被请求 {frequentHitThreshold} 次以进行缓存的时间间隔。默认为 10 秒。请注意,无论您设置的 frequentHitTimePeriod 是什么,如果 1 分钟后没有请求,频繁的文件将始终变得不频繁。我不知道配置中是否有此设置。
例如,设置
frequentHitThreshold
为 1 意味着 IIS 始终认为该文件很频繁,即使从第一次请求开始也是如此。这将依次绕过动态压缩并仅由静态压缩处理。请注意,动态(默认 0)和静态(默认 7)压缩的压缩级别不同,因此将返回 2 个不同的文件大小。
此外,这也是我首先陷入这个问题的原因:同一文件的 ETag 在动态压缩和静态压缩之间是不同的,即使您对两者使用相同的级别也是如此。
希望这可以帮助。
显然,在第一次请求静态文件时,IIS 在其压缩文件缓存中没有该文件的压缩副本,因此它对该请求使用动态压缩。这可以通过将
serverRuntime
元素的frequentHitTHreshold
属性设置为 1 来解决。这将在此处详细讨论。此设置可能仅在为 CDN 提供服务时才值得更改。
在此处查找有关 IIS 动态压缩的更多详细信息:
http://www.west-wind.com/weblog/posts/2011/May/05/Builtin-GZipDeflate-Compression-on-IIS-7x
基本上随着服务器上的高 CPU 负载,完成较少的压缩
这里有更多详细信息以及如何配置压缩级别:
http://weblogs.asp.net/owscott/archive/2009/02/22/iis-7-compression-good-bad-how-much.aspx