77人参与 • 2025-03-07 • 缓存
强缓存直接告诉浏览器:在缓存过期前,无需与服务器通信,直接使用本地缓存。
由服务器通过响应头 cache-control
和 expires
控制。
cache-control: max-age=3600
表示资源在 3600 秒(1小时) 内有效(优先级高于 expires
)。
expires: thu, 31 dec 2030 23:59:59 gmt
指定一个绝对过期时间(依赖于客户端本地时间,可能存在误差)。
location /static/ { # 设置强缓存:1年内有效 add_header cache-control "public, max-age=31536000"; expires 1y; }
浏览器首次请求资源时,服务器返回资源并附带缓存头。
后续请求时,浏览器直接读取本地缓存(状态码 200 (from disk cache)
),不发送请求到服务器。
静态资源(如 css、js、图片、字体文件)等长期不变的资源。
协商缓存要求浏览器 每次向服务器验证缓存是否过期,若未过期则返回 304 not modified
,继续使用本地缓存。
由服务器通过响应头 last-modified
和 etag
控制。
last-modified: wed, 21 oct 2023 07:28:00 gmt
表示资源最后修改时间(精度为秒,可能因时间同步问题失效)。
etag: "5d8c72a5-264"
资源的唯一标识符(哈希值或版本号),精度更高。
location /dynamic/ { # 启用协商缓存(默认已支持,无需显式配置) add_header last-modified ""; etag on; }
浏览器首次请求资源时,服务器返回资源并附带 last-modified
或 etag
。
后续请求时,浏览器通过以下请求头验证缓存:
if-modified-since: [last-modified值]
向服务器询问资源是否在指定时间后修改过。if-none-match: [etag值]
向服务器验证资源的 etag
是否变化。若资源未修改,服务器返回 304 not modified
,浏览器继续使用缓存;若已修改,返回新资源(状态码 200
)。
频繁更新的资源(如 html 页面、动态 api 响应)。
特性 | 强缓存 | 协商缓存 |
---|---|---|
通信成本 | 无网络请求(直接读缓存) | 需发送请求验证缓存 |
响应状态码 | 200 (from disk cache) | 304 not modified |
优先级 | 优先于协商缓存 | 强缓存过期后触发 |
适用资源 | 长期不变的静态资源 | 频繁更新的动态资源 |
1.混合使用两种缓存
location / { # 强缓存 1 小时,过期后启用协商缓存 add_header cache-control "public, max-age=3600"; etag on; }
2.按文件类型区分策略
# 图片、字体等强缓存 location ~* \.(jpg|png|gif|woff2)$ { expires 1y; add_header cache-control "public, max-age=31536000"; } # html 文件禁用强缓存(总是协商) location ~* \.html$ { add_header cache-control "no-cache, must-revalidate"; }
3.解决缓存更新问题
强缓存资源建议通过 文件名哈希 控制版本(如 main.abcd1234.js
)。
协商缓存可通过修改 etag
或 last-modified
触发更新。
浏览器开发者工具(network 标签):
200 (from disk cache)
(强缓存)或 304 not modified
(协商缓存)。cache-control
、if-modified-since
、if-none-match
。命令行工具:
curl -i http://example.com/resource.js
通过合理配置强缓存和协商缓存,可以显著提升网站性能,减少服务器负载。
到此这篇关于一文详解nginx的强缓存和协商缓存的文章就介绍到这了,更多相关nginx缓存内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论