frontend-notes

缓存策略

HTTP报文格式

通用信息头指的是请求和响应报文都支持的头域,分别为Cache-ControlConnection、DatePragmaTransfer-EncodingUpgrade、Via; 实体头则是实体信息的实体头域,分别为AllowContent-BaseContent-EncodingContent-LanguageContent-LengthContent-LocationContent-MD5Content-RangeContent-TypeEtagExpiresLast-Modifiedextension-header。这里只是为了方便理解,将通用信息头,响应头/请求头,实体头都归为了HTTP头。

缓存策略

浏览器缓存策略分为”强制缓存“和”协商缓存,强制缓存优先于协商缓存进行,若强制缓存(Expires和Cache-Control)生效则直接使用缓存,若不生效则进行协商缓存(Last-Modified / If-Modified-Since和Etag / If-None-Match),协商缓存由服务器决定是否使用缓存,若协商缓存失效,那么代表该请求的缓存失效,重新获取请求结果,再存入浏览器缓存中;生效则返回304,继续使用缓存

强缓存

强制缓存就是向浏览器缓存查找请求结果,并根据该结果的缓存规则来决定是否使用该缓存结果的过程

浏览器怎么判断是否存在缓存和缓存是否失效?(强制缓存的缓存规则)

当浏览器向服务器发起请求时,服务器会将缓存规则放入HTTP响应报文的HTTP头中和请求结果一起返回给浏览器,控制强制缓存的字段分别是ExpiresCache-Control其中Cache-Control优先级比Expires

协商缓存

协商缓存就是强制缓存失效后,浏览器携带缓存标识向服务器发起请求,由服务器根据缓存标识决定是否使用缓存的过程,主要有以下两种情况:

协商缓存的标识也是在响应报文的HTTP头中和请求结果一起返回给浏览器的,控制协商缓存的字段分别有:Last-Modified / If-Modified-SinceEtag / If-None-Match,其中Etag / If-None-Match的优先级比Last-Modified / If-Modified-Since高。

缓存流程图

browser-缓存策略-浏览器缓存

其他知识点

内存缓存(from memory cache)和硬盘缓存(from disk cache)

缓存分 内存缓存 和 硬盘缓存,浏览器读取缓存的顺序为memory –> disk

在浏览器中,浏览器会在js和图片等文件解析执行后直接存入内存缓存中,那么当刷新页面时只需直接从内存缓存中读取(from memory cache);而css文件则会存入硬盘文件中,所以每次渲染页面都需要从硬盘读取缓存(from disk cache)。

在浏览器控制台可以查看哪些资源是内存缓存,哪些资源是硬盘缓存,如下图: browser-缓存策略-内存缓存&硬盘缓存调试

参考