http缓存 尼古拉斯

一、什么是http缓存

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

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

二、缓存规则

 1、强制缓存

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

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

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

  主要通过两个字段控制:

  优先级:Cache-Control > Expires

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

  

  Cache-Control:Cache-Control字段后可以接一下相对时间,max-age 单位秒,缓存在这个max-age最大时间内有效

  

  

  1、协商缓存

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

     两个控制字段:

   优先级:Etag > Last-Modified

  Last-Modified:标识的是资源在服务器上的最后修改时间,服务器会对比资源在最后修改时间之后是否有变动,有则返回新的资源,没有则返回304

   

    Etag:Etag 是由服务器为每个资源生成的唯一的标识字符串,这个标识字符串是基于文件内容编码的,只要文件内容不同

    它们对应的 Etag 就是不同的,因此 Etag 能够精准地感知文件的变化

  

三:缓存读取

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

  

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

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

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

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

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

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

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

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

原文地址:https://www.cnblogs.com/xxflz/p/15607771.html