代码改变世界

网站性能优化 --- Expires、Cache Control、Etags

2019-05-23 07:11  *奋斗*  阅读(199)  评论(0)    收藏  举报

1、Expires

优点:http 1.0 就有,简单易用。服务器通过这个Header告诉浏览器,某资源直到某个时间才会过期,所以在过期之前,浏览器就直接使用本地缓存。
缺点:因为这个时间是由服务器发送的(UTC),但如果服务器时间和客户端时间存在不一致,可能会有些问题;可能存在版本的问题,因为如果在到期之前修改过了,客户端是不会知道的。相比之下,Cache-Control中的max-age可以实现类似的效果,但更加好,因为max-age是一个以秒为单位的时间数,而不是具体的时间,所以不存在上面提到的第一个问题。

2)Cache-Control

优点:服务器通过一个Header(Last-Modified)告诉浏览器,某资源最后修改的时间。浏览器在请求的时候,包含一个Header(If-Modified-Since),然后服务器可以进行比较,如果在该时间后没有修改过,则返回304。它比Expires多很多选项设置。
缺点:Last-Modified 也是一个时间,但该时间只能精确到秒,如果在同一个秒中有多次修改(这个在现在的环境下应该确实是可能的),则可能会发生问题。

3)ETag
优点:可以更加精确地判断资源是否被修改,因为它不是一个时间值,而是对时间经过处理的一个长字符串。浏览器发起新请求时需要包含 If-None-Match。
缺点:如果部署在服务器环境中,配置不当的话,可能每个服务器会对相同的资源生成不一样的ETag,这样就增加了重复下载的可能性。要理解这个问题的原因,以及如何解决,请参考这里的文档:http://support.microsoft.com/kb/922703/en-us,该问题在IIS 7以及以后的版本中应该不存在了。

这几个技术其实很多时候是会结合起来用的,而且优先级也有所不同。通常,ETag是优先于Cache-Control的,而Cache-Control又是优先于Expires的。