Nginx 关于http中Cache-Control详解
Nginx 关于http中Cache-Control详解
为了优化网站,需要在缓存中着手看看,看到有关nginx cache—control 的设置
网页的缓存是由http消息头中的“Cache-control”来控制的,常见的取值有public、private、no-cache、max-age、must-revalidate等,默认为private。其作用根据不同的重新浏览方式分为以下几种情况:
-
public
- 新打开一个窗口: 不会去访问服务器
- 原页面回车:不会去访问服务器,取自缓存
- 刷新:浏览器重新请求服务器
- 单击返回按钮:页面取自缓存
-
private
- 新打开一个窗口:浏览器重新发送请求到服务器
- 原页面回车:第一次会去请求服务器,以后均是来自于缓存
- 刷新:浏览器重新请求服务器
- 单击返回按钮:页面取自缓存
-
no-cache/no-store
- 打开新窗口、回车 、刷新、单击返回:均会访问请求服务器;
- 这里要说明的是:no-cache 不是没有缓存,只不过每次在向客户端(浏览器)提供响应数据时,缓存都要向服务器评估缓存响应的有效性;
- Cache-Control: no-store:这个才是响应不被缓存的意思。
-
must-revalidation/proxy-revalidation
- 打开新窗口:浏览器重新发送请求到服务器
- 原页面回车:第一次请求服务器,以后均是来自缓存页面
- 刷新:浏览器重新请求服务器
- 单击返回按钮:页面取自缓存
-
max-age=xxx
- 刷新按钮:重新发送请求到服务器;其他的均是在访问页面XXX秒后一直来自缓存;
总结:
- 打开新窗口 如果指定cache-control的值为private、no-cache、must-revalidate,那么打开新窗口访问时都会重新访问服务器。而如果指定了max-age值,那么在此值内的时间里就不会重新访问服务器,例如:Cache-control: max-age=5 表示当访问此网页后的5秒内不会去再次访问服务器.
- 在地址栏回车 如果值为private或must-revalidate,则只有第一次访问时会访问服务器,以后就不再访问。如果值为no-cache,那么每次都会访问。如果值为max-age,则在过期之前不会重复访问。
- 按后退按扭 如果值为private、must-revalidate、max-age,则不会重访问,而如果为no-cache,则每次都重复访问.
- 按刷新按扭 无论为何值,都会重复访问.
Expires是个好东东,如果服务器上的网页经常变化,就把它设置为-1,表示立即过期。如果一个网页每天凌晨1点更新,可以把Expires设置为第二天的凌晨1点。
当HTTP1.1服务器指定CacheControl = no-cache时,浏览器就不会缓存该网页。
旧式 HTTP 1.0 服务器不能使用 Cache-Control 标题。
所以为了向后兼容 HTTP 1.0 服务器,IE使用Pragma:no-cache 标题对 HTTP 提供特殊支持。
Pragma: no-cache可以应用到http 1.0 和http 1.1,而Cache-Control: no-cache只能应用于http 1.1.
Nginx下配置Cache-Control头
在请求消息或响应消息中设置 Cache-Control并不会影响另一个消息处理过程中的缓存处理过程。
请求时的缓存指令包括no-cache、no-store、max-age、 max-stale、min-fresh、only-if-cached等。
响应消息中的指令包括public、private、no-cache、no- store、no-transform、must-revalidate、proxy-revalidate、max-age。
Nginx的ngx_http_headers_module模块可以对Cache-Control头相关的东西进行配置
例如:
# 相关页面设置Cache-Control头信息 if ($request_uri ~* "^/$|^/search/.+/|^/company/.+/") { add_header Cache-Control max-age=3600; } if ($request_uri ~* "^/search-suggest/|^/categories/") { add_header Cache-Control max-age=86400; }
个人理解的max-age意思是:客户端本地的缓存,在配置的生存时间内的,客户端可以直接使用,超出生存时间的,到服务器上取新数据。当然这些还要看客户端浏览器的设置。
PS:必须配合Last-Modified使用
文章参考:
1. http://blog.csdn.net/kane_canpower/article/details/56487591
2. http://www.cnblogs.com/jason-zy/archive/2012/03/06/2381433.html