HTTP的缓存机制
在介绍HTTP缓存之前,作为知识铺垫,我们再来复习一下之前写的HTTP报文
HTTP报文就是浏览器和服务器间通信时发送及响应的数据块。
浏览器向服务器请求数据,发送请求(request)报文;服务器向浏览器返回数据,返回响应(response)报文。
报文信息主要分为两部分
- 包含属性的首部(header)--------------------------附加信息(cookie,缓存信息等)与缓存相关的规则信息,均包含在header中
- 包含数据的主体部分(body)-----------------------HTTP请求真正想要传输的部分
缓存是什么
缓存是一种保存资源副本并在下次请求时直接使用该副本的技术。当web缓存发现请求的资源已经被存储,他会拦截请求,返回该资源的拷贝,而不会去源服务器重新下载
缓存需要合理配置,因为并不是所有资源都是永久不変的。重要的是对一个资源的缓存应截止到其下次发生改变(即不能缓存过期的资源)。
下面我们来看一下有缓存的图和无缓存的图他们的不同之处
☆再给大家来一个图,这两个图差不多,那个能看懂看那个。
接下来,让我们来一块了解一下缓存的优势
缓存的优势
- 缓解服务器端的资源消耗和运行压力,提升服务器端的整体性能。
- 减少服务器端资源加载的延迟,进而减少显示某个资源所用的时间
- 减少对带宽造成的压力,避免网络阻塞问题的出现
- Web站点变得更具有响应性
缓存应用
常见的HTTP缓存只能存储GET响应,对于其他类型的响应则无能为力。
- 检索请求的成功响应:响应状态码为200,则表示为成功。包含例如HTML文档,图片,或者文件的响应。
- 不变的重定向:响应状态码为301
- 错误响应:响应状态码为404的一个页面。
- 不完全的响应:响应状态码为206,只返回局部的信息。
- 除了GET请求外,如果匹配到作为ー个已被定义的cache键名的响应。
之后我们再来了解一下缓存的类型
缓存类型
私有缓冲
私有缓存只能用于单独用户。洳览器缓存拥有用户通过HTTP下载的所有文档。这些缓存为浏览过的文档提供向后/向前导航、保存网页、查看源码等功能,可以避免再次向服务器发起多余的请求。它同样可以提供缓存內容的离线览。
Cache-Control:private
共享缓存
共享缓存可以被多个用户使用。例如,ISP或所在的公司可能会架设一个web代理来作为本地网络基础的一部分提供给用户。这样热门的资源就会被重复使用,减少网络拥堵与延迟
Cache-Control:public
Cacke-control头
HTTP/1.1定义的Cache-Control头用来区分对缓存机制的支持情况,请求头和响应头都支持这个属性。通过它提供的不同的值来定义存策略。
-
禁止进行缓存
Cache-Control: no-store Cache-Control: no-cache, no-store, must-revalidate
-
强制确认缓存
Cache-Control: no-cache
-
缓存过期机制
Cache-Control: max-age=31536000
-
缓存验证确认
Cache-Control: must-revalidate
❤❤❤=ω= 整理不易,点个赞再走吧 =ω= ❤❤❤