百度优化建议的FAILED – (未设置max-age或expires)

我们在优化网站的时候,喜欢到百度站长平台检测网站的优化效果,大家肯定都遇到过这样的问题,如下图:

百度优化建议的FAILED - (未设置max-age或expires)

对于这种问题,我们应该怎么解决呢?首先,我们要弄清楚什么是expires。

expires属性指定了coolie的生存期,默认情况下coolie是暂时存在的,他们存储的值只在浏览器会话期间存在,当用户推出浏览器后这些值也会丢失,如果想让cookie存在一段时间,就要为expires属性设置为未来的一个过期日期。现在已经被max-age属性所取代,max-age用秒来设置cookie的生存期。

Squid和Apache中的max-age与Expires的分别

max-age是HTTP/1.1中,他是指我们的web中的文件被用户访问(请求)后的存活时间,是个相对的值,相对Request_time(请求时间).
例如:A.html  用户请求时间是18:00,max-age设置的是600的话,相当18:00+600秒过期,也就是相对18:00的时间后面600秒后过期.默认的max-age是由Expires算出来的。

Expires是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-age

2、绝对修改时间(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的值是缓存服务器算出来的,原始服务器是没有的。

apache 设置expires和max-age缓存

对于同一个操作对象,ExpiresByType比ExpiresDefault优先级高.当expires和max-age同时存在时,max-age的优先级会高于expires.

当你不知道某个文件的MIME类型时,你可以通过浏览器去看httpwatch去看MIME类型.

如果要对某个目录里的某个文件设置Expires头,可以用<filesmatch "正则"></filematch>来匹配.

设置缓存也可以通过mod_headers模块修改cache-control来实现.

mod_expires 实例:

mod_headers实例

部分内容来自网络,欢迎大家批评指正。

附:百度经验的解决方法

俊霖

发表评论

您必须