HTTP cache in depth All In One
HTTP cache in depth All In One
HTTP 缓存
https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Caching_FAQ
HTTP Headers 不区分大小写 ✅
HTTP headers are not case sensitive ???
https://stackoverflow.com/questions/5258977/are-http-headers-case-sensitive
https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/
强缓存 200
-
Expires (
HTTP/1.0
) 👎 -
Cache-Control (
HTTP/1.1
) 👍
max-age
s-maxage
public
private
优先级 Cache-Control
高
协商缓存 304
HTTP 304 Not Modified 说明无需再次传输请求的内容,也就是说可以使用缓存的内容。这通常是在一些安全的方法(safe),例如GET 或HEAD 或在请求中附带了头部信息: If-None-Match 或If-Modified-Since。
如果是 200 OK ,响应会带有头部 Cache-Control, Content-Location, Date, ETag, Expires,和 Vary.
https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Status/304
https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Status/200
ETag
/ If-None-Match
Last-Modified
/ If-Modified-Since
优先级 ETag
高
强缓存 & 协商缓存
强缓存:
expires
Cache-Control
协商缓存:
ETag
/ If-None-Match
Last-Modified / If-Modified-Since
浏览器缓存 / web 缓存
- Memory Cache
- Service Worker
- HTTP cache
- Application Cache API (已弃用⚠️)
...
memory cache
200
cache-control / ETag
http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9
https://github.com/h5bp/server-configs
http://httparchive.org/trends.php#maxage0
PWA
cookie
LocalStorage
SessionStorage
IndexedDB
Web SQL (已弃用⚠️,停止维护,支持者太少了,sqlite)
https://developers.google.com/web/tools/chrome-devtools/storage/applicationcache
https://html.spec.whatwg.org/multipage/offline.html#offline
https://developers.google.com/web/tools/chrome-devtools/storage/websql
https://www.w3.org/TR/webdatabase/#status-of-this-document
HTTP/1.1 HTTP/2 HTTP/3 (QUIC)
- 多路复用
http cache 缓存的位置
https://segmentfault.com/a/1190000020086923
从缓存位置上来看,分为4种,从上往下依次检查是否命中,如果但都没有命中则重新发起请求。
Service Worker 是运行在浏览器背后的独立线程,一般可以用来实现缓存功能。
使用 Service Worker的话,传输协议必须为 HTTPS。
Memory Cache 也就是内存中的缓存,主要包含的是当前中页面中已经抓取到的资源,例如页面上已经下载的样式、脚本、图片等。读取内存中的数据肯定比磁盘快,内存缓存虽然读取高效,可是缓存持续性很短,会随着进程的释放而释放。
一旦我们关闭 Tab 页面,内存中的缓存也就被释放了。
内存缓存中有一块重要的缓存资源是preloader相关指令(例如)下载的资源。
它可以一边解析js/css文件,一边网络请求下一个资源。
Disk Cache 也就是存储在硬盘中的缓存,读取速度慢点,但是什么都能存储到磁盘中,比之 Memory Cache 胜在容量和存储时效性上。
绝大部分的缓存都来自Disk Cache,在HTTP 的协议头中设置。
Push Cache(推送缓存)是 HTTP/2 中的内容,当以上三种缓存都没有命中时,它才会被使用。
它只在会话(Session)中存在,一旦会话结束就被释放,并且缓存时
refs
©xgqfrms 2012-2021
www.cnblogs.com/xgqfrms 发布文章使用:只允许注册用户才可以访问!
原创文章,版权所有©️xgqfrms, 禁止转载 🈲️,侵权必究⚠️!
本文首发于博客园,作者:xgqfrms,原文链接:https://www.cnblogs.com/xgqfrms/p/12885582.html
未经授权禁止转载,违者必究!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
2019-05-13 How to write a Node.js cli tools step by step tutorials All In One
2019-05-13 svn conflict & svn cleanup
2019-05-13 node.js & read argv
2019-05-13 Node.js & create file All In One