负载均衡环境中和如何设置Expires和Etag .
在负载均衡环境中(LVS, LoadBalance)为了减少浏览器数据的重复请求操作,一般需要设置 Http Header 的 Etage 和 Expires 告诉浏览器请求数据是否已过期。以下内容主要考虑Apache+squid 环境
ETag Header是文件修改时间、文件大小和inode号生成的校验(checksum),在多台服务器的负载均衡环境下会因部署内容的inode节点差异造成 ETag 的不同,在多台WEB前端做负载均衡的情况下,会因为请求同一个数据但不同机器的 ETag 而影响了响应. 具体表现为用户在第一次请求某一内容时下载而再次时浏览器会发现ETag不同而再次请求下载.。(再次刷新时查看是否响应码为:304)
对于Apache可以使用FileEtag选项配置
Apache的默认ETag的值总是由文件的索引节点(Inode)、大小(Size)、最后修改时间(MTime)决定
这里我们只需要去掉Inode即可
FileETagMTimeSize
具体关于 FileETag 详细内容可以查看Apache官方文档。Expires用于控制请求文件的有效时间,当请求数据在有效期内时客户端浏览器从缓存请求数据而不是服务器端. 当缓存中数据失效或过期,才决定从服务器更新数据。
可以使用Apache的mod_expires模块来设置,这包括控制应答时的Expires头内容和Cache-Control头的max-age指令
ExpiresActiveOn
ExpiresByTypeimage/gif“accessplus1month”
ExpiresByTypeimage/jpeg“accessplus1month”
ExpiresByTypeimage/x-icon“accessplus1month”
ExpiresByTypeimage/png“accessplus1month”
ExpiresByTypetext/html“accessplus30minutes”
ExpiresByTypetext/css“accessplus30minutes”
ExpiresByTypetext/js“accessplus30minutes”
ExpiresByTypeapplication/x-javascript“accessplus30minutes”
ExpiresByType application/x-shockwave-flash “access plus 30 minutes”以上设置为 图片文件的有效期为从请求文件开始1个月,html,css,js,flash文件的有效期为从请求文件开始30分钟
这里只是一个常规设置,Apache官方文档对此设置有详细介绍
当设置了expires后,会自动输出Cache-Control的max-age信息,这个数值是expires有效期内的秒数,(一个月的数值为2592000)在这个时间段里,该文件的请求都将直接通过缓存服务器获取,当然如果需要忽略浏览器的刷新请求(F5),缓存服务器squid还需要使用refresh_pattern选项来忽略该请求
refresh_pattern-i.jpg144050%10080reload-into-imsignore-reloadignore-no-cacheignore-private
以下为实际输出的HTTPHeader信息
DateThu,07Aug200807:27:57GMT
ServerApache
Last-ModifiedFri,27Jun200807:18:52GMT
Etag“df6-b8c8cf00″
Accept-Rangesbytes
Content-Length3574
Cache-Controlmax-age=2592000
ExpiresSat,06Sep200807:27:57GMT
Content-Typeimage/jpeg
Age34241
X-CacheHITfroms1.ihompy.com
Connectionkeep-alive
对于动态页面的缓存如果不是频繁更新的页面数据,可以在squid缓存,只需要注意两点
1.session:对于需要缓存的数据,一定要关闭session防止在httpheader中包括sessionid字段
2.Last-Modified和Expires标记:一般般纯静态页面本身都会有Last-Modified信息,这是由WEB服务器获取文件的最后修改时间生成的,而动态页面需要默认的输出内容是
DateThu,07Aug200816:58:37GMT
ExpiresThu,19Nov198108:52:00GMT
Last-ModifiedThu,07Aug200816:58:37GMT
这里的Last-Modified时间和请求文件的时间相同,也就是说该文件总是声明为最新的
在程序中需要输出Last-Modifed和Expires信息,比如php
header(‘Last-Modified:‘.gmdate(“D,dMYH:i:s”).‘GMT’);
header(‘Expires:‘.gmdate(“D,dMYH:i:s”,time()+3600*24).”GMT”);
以上信息设置php文件的过期时间为请求该文件的时间后的24小时(3600*24)
Squid和Apache中的max-age与Expires的分别主要重点在于我们要明白一个相对(Expires)一个绝对(max-age).
分别
max-age
max-age是HTTP/1.1中,他是指我们的web中的文件被用户访问(请求)后的存活时间,是个相对的值,相对Request_time(请求时间).
例如:A.html 用户请求时间是18:00,max-age设置的是600的话,相当18:00+600秒过期,也就是相对18:00的时间后面600秒后过期.默认的max-age是由Expires算出来的.ExpiresExpires是HTTP/1.0中的,它比max-age要麻烦点.Expires指定的时间分下面二种,这个主要考虑到apache中设置是A还是M.
1.相对文件的最后访问时间(Atime)当Apache使用A时间来做Expires时.这样设置时.他就和max-age的值相等,因为max-age是相对文件的请求时间(Atime).
例如:ExpiresByType text/html A600
由上面我们得知,Apache设置Atime时,过期为600秒时.
Expires=18:00+600=18:10
max-age=18:00+600=18:10
得出:Expires=max-age2.绝对修改时间(MTime)
这又分二种情况,我们来拿A.htm来讲
假设文件的建立时间为18:00.当用户Request请求为18:00时,过期为600秒
Expires=18:00+600=18:10
max-age=18:00+600=18:10
得出:Expires等于max-age当用户Request请求为18:20时,过期为600秒
Expires=18:00+600=18:10(因为设置成Mtime时,时间由文件建立时间来决定)
max-age=18:20+600=18:30
得出:Expires不等于max-age另外要注意,象上面这种清况时,max-age优化,所以过期时间为18:30.
在squid,如果没有指明expires和max-age这二个的截止时间,那它就会使用发式截止时间,如参考 Last-Modified.
其实上面的max-age=18:20+600=18:30,这样算max-age不对,真实环境要这样算,max-age过期为http头中的Age=600过期.
注:Age域值是缓存服务器估计从响应产生或被原始服务器重新证实以来的总时间.age的值是缓存服务器算出来的,原始服务器是没有的.http://hi.baidu.com/lijunwyf/blog/item/f109aa00ed122f19728da54e.html