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秒后一直来自缓存;

总结:

  1. 打开新窗口 如果指定cache-control的值为private、no-cache、must-revalidate,那么打开新窗口访问时都会重新访问服务器。而如果指定了max-age值,那么在此值内的时间里就不会重新访问服务器,例如:Cache-control: max-age=5 表示当访问此网页后的5秒内不会去再次访问服务器.
  2. 在地址栏回车 如果值为private或must-revalidate,则只有第一次访问时会访问服务器,以后就不再访问。如果值为no-cache,那么每次都会访问。如果值为max-age,则在过期之前不会重复访问。
  3. 按后退按扭 如果值为private、must-revalidate、max-age,则不会重访问,而如果为no-cache,则每次都重复访问.
  4. 按刷新按扭 无论为何值,都会重复访问.

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头

 

HTTP协议的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

转载于:https://www.cnblogs.com/wpjamer/articles/7134227.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
缺少HTTP响应头Cache-Control字段可能会导致缓存控制不生效。在缺失Cache-Control字段的情况下,浏览器和代理服务器可能会默认将响应内容缓存起来,这可能会导致一些问题。为了解决这个问题,可以在HTTP响应头添加Cache-Control字段来控制缓存行为。常见的Cache-Control取值有public、private、no-cache、max-age、must-revalidate等。其,no-cache表示每次请求都要向服务器评估缓存响应的有效性,而max-age表示缓存的最大有效时间。通过设置合适的Cache-Control值,可以确保缓存行为符合预期。另外,还可以使用Pragma字段和Expires字段来进一步控制缓存行为。Pragma字段的值可以设置为no-cache,表示不缓存内容,而Expires字段可以设置为过去的时间,相当于Cache-Control:no-cache的效果。因此,为了解决缺失Cache-Control的问题,可以在HTTP响应头添加类似以下的代码:header('Cache-Control: no-store, no-cache, must-revalidate'); header("Expires: Mon, 26 Jul 1970 05:00:00 GMT"); \[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [HTTP缓存带来的“bug”--HTTP 协议 Cache-Control](https://blog.csdn.net/weixin_30924239/article/details/98981719)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Nginx 关于httpCache-Control详解](https://blog.csdn.net/kane_canpower/article/details/56487591)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值