新浪博客

http缓存(强制缓存和协商缓存)

2023-03-27 09:08阅读:
http缓存(强制缓存和协商缓存) 先说说缓存原理:
在首次请求后,保存一份请求资源的响应副本,当用户再次发起相同的请求后,判断是不是之前的请求,如果是,则会拦截,将之前储存的响应副本返回给用户,从而避免重新向服务器发起资源请求
针对于缓存技术,比如代理缓存,浏览器缓存,网关缓存,负载均衡器及内容分发网络等,它们大致分为两类,共享缓存和私有缓存,共有缓存指的是缓存内容可被多个用户使用,如公司内部架设的Web代理; 私有缓存指的是只能单独被用户使用的缓存,如浏览器缓存
浏览器缓存(Brower Caching)是浏览器在本地磁盘对用户最近请求过的文档进行存储,当访问这再次访问同一页面时,浏览器就会直接从本地磁盘加载文档
浏览器缓存的优点:
1、减少冗余的数据传输,节省网费
2、减少服务器的负担,大大提升网站性能
3、加快客户端加载网页的速度
http缓存: 分为强制缓存和协商缓存,两者区别在于判断缓存命中时,浏览器是否需要向服务端进行询问以协商缓存的相关信息,进而判断是否需要就响应内容进行重新请求
强制缓存:
不会向服务器发送请求,直接从缓存中读取资源,在chrome控制台的network选项中可以看到该请求返回200的状态码。
强制缓存的header参数
Expires(现在不用了,因为在加载资源的时候,它会有个弊端,它本身的时间是有问题的): response header 里的过期时间,浏览器再次加载资源时,如果在这个过期时间内,则命中强缓存
Cac
he-Control(http协议更新中加了 Cache-Control,): 当值设为max-age=300时,则代表在这个请求正确返回时间(浏览器也会记录下来)的5分钟内再次加载资源,就会命中强缓存
cache-control(缓存控制)除了该字段外,还有下面几个比较常用的设置值
-no-cache: 不使用本地缓存。需要使用协商缓存,先与服务器确认返回的响应是否被更改,如果之前的响应中存在ETag,那么请求的时候会与服务端验证,如果资源未被更改,则可以避免重新下载
-no-store:直接禁止浏览器缓存数据,每次用户请求该资源,都会向服务器发送一个请求,每次都会下载完整的资源
-public:可以被所有的用户缓存,包括终端用户和CDN等中间代理服务器
-private: 只能被终端用户的浏览器缓存,不允许CDN等中继缓存服务器对其缓存
Expires和Cache-Control的区别
Expires 设置以分钟为单位的绝对过期时间,设置相对过期时间,max-age指明以秒为单位的缓存时间
Expires 优先级比Cache-Control低,同时设置Expires和Cache-Control则后者生效
协商缓存:
在使用本地缓存之前,需要向服务器发送请求,服务器会根据这个请求的request header的一些参数来判断是否命中协商缓存,如果命中(也就说,没有新的数据出现),则返回304状态码并带上新的response header通知浏览器从缓存中读取资源,(如果有新的数据,怎返回200及新的数据),协商缓存可以解决强制缓存的情况下,资源不更新的问题(服务器响应给我们浏览器,那些信息记录在请求头和响应头 )
协商缓存中header的参数
设置协商缓存: cache-control: no-cache
Last-Modify/If-Modify-Since: 浏览器第一次请求一个资源的时候,服务器返回的header中会加上Last-Modify,Last-modify是一个时间标识该资源的最后修改时间,当浏览器再次请求该资源时,request的请求头中包含If-Modify-Since,该值为缓存之前返回的Last-Modify. 服务器收到If-Modify-Since后,根据资源的最后修改时间判断是否命中缓存
Last-Modify的值是资源最后修改时间
Etag/If-None-Match: web服务器响应请求时,告诉浏览器当前资源在服务器的唯一标识(生成规则由服务器决定)。If-None-Match:发现资源具有Etag声明,则再次向web服务器请求时带上头If-None-Match(Etag的值)。web服务器收到请求后发现有头If-None-Match则与被请求资源的相应校验串进行比对,决定是否命中协商缓存
Etag的值是文件对应的hash值(但是会加大服务器的开销,这个hash是需要生成的)
Etag和Last-Modify的作用和用法,及区别
  • 1.Etag要优于Last-Modified。 Last-Modified的时间单位是秒,如果某个文件在1秒内改变了多次,那么他们的Last-Modified其实并没有体现出来修改,但是Etag每次都会改变确保了精度;
  • 2在性能上,Etag要逊于Last-Modified,毕竟Last-Modified只需要记录时间,而Etag需要服务器通过算法来计算出一个hash值;
  • 3.在优先级上,服务器校验优先考虑Etag

我的更多文章

下载客户端阅读体验更佳

APP专享