http缓存

一、什么是http缓存

  http缓存就是在浏览器从服务端请求的资源,通过缓存规则保存在浏览器本地,二次请求的时候不再从服务端获取

  而是直接从本地获取缓存资源,降低了 服务器压力,提升了加载速度

二、缓存规则

 1、强制缓存

  首次请求服务端资源时,服务端会在Response Headers 中写入缓存时间。当请求再次发出时,

  如果缓存时间内,将直接从缓存获取资源,而不会再与服务器发生通信。

  如果不在缓存时间内,与服务器发生通信。

  主要通过两个字段控制:

  Expires:Expires字段后面会接一个绝对时间,在这个绝对时间之前强缓存有效,Expires目前已经废弃

  

  Cache-Control:Cache-Control 是 Expires 的替代方案,可以有几个值:

       max-age : 单位秒,缓存在这个max-age最大时间内有效

  

  no-cache:跳过强制缓存,采用协商缓存

  no-store:完全不缓存

  2、协商缓存

   协商缓存机制下,浏览器需要向服务器去询问缓存的相关信息,进而判断是重新发起请求,还是从本地获取缓存的资源

     两个控制字段:

    Last-Modified:标识的是资源在服务器上的最后修改时间,当第一次请求的时候,服务会返回 Last-Modified ,当再次请求的时候请求头

    会带上 If-Modified-Since:xx(第一次请求返回的 Last- Modified的值),服务器会对比资源在最后修改时间之后是否有变动,有则返回新的资源,

         没有则返回  304

   

 

    Etag:Etag 是由服务器为每个资源生成的唯一的标识字符串,当第一次请求的时候,服务会返回 Etag 值 ,当再次请求的时候请求头

    会带上 if-None-Match:xx(第一次请求返回的 Etag 的值)这个标识字符串是基于文件内容编码的,只要文件内容不同

    它们对应的 Etag 就是不同的,因此 Etag 能够精准地感知文件的变化,Etage也是Last-Modified的替代方案

  

 

 

 

 

三:缓存读取

  浏览器缓存到底缓存在哪里?

  

 

    from memory cache代表使用内存中的缓存

  from disk cache则代表使用的是硬盘中的缓存

  • 内存缓存(from memory cache):内存缓存具有两个特点,分别是快速读取和时效性:

  • 快速读取:内存缓存会将编译解析后的文件,直接存入该进程的内存中,占据该进程一定的内存资源,以方便下次运行使用时的快速读取。

  • 时效性:一旦该进程关闭,则该进程的内存则会清空。

  • 硬盘缓存(from disk cache):硬盘缓存则是直接将缓存写入硬盘文件中,读取缓存需要对该缓存存放的硬盘文件进行I/O操作,然后重新解析该缓存内容,读取复杂,速度比内存缓存慢。

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

  所以每次渲染页面都需要从硬盘读取缓存(from disk cache)。

posted @ 2021-11-26 14:37  尼古拉斯-富贵  阅读(956)  评论(0编辑  收藏  举报