浏览器缓存机制

对于web应用来说,它是提升页面性能同时减少服务器压力的利器。

  • 浏览器缓存过程

    1. 浏览器第一次加载资源,服务器返回200,浏览器将资源文件从服务器上请求下载下来,并把response header及该请求的返回时间一并缓存;
    2. 下一次加载资源时,先比较当前时间和上一次返回200的时间差,没有超过cache-control设置的max-age(如果服务器不支持http1.1,则用expires判断是否过期),则没有过期,命中强缓存,不发送请求直接从本地缓存读取该文件。如果过期,则向服务器发送header带有if-None-Match和if-Modified-Since的请求;
    3. 服务器收到请求后,优先根据Etag的值判断被请求的文件有没有做修改,Etag值一致则没有修改,命中协商缓存,返回304;如果不一致则有改动,直接返回新的资源文件带上新的Etag值并返回200;
    4. 如果服务器收到的请求没有Etag值,则将if-Modified-Since和被请求文件的最后修改时间做比较,一致则命中协商缓存,返回304;不一致则返回新的last-Modified和文件返回200。
  • 浏览器缓存类型分为 ==强缓存====协商缓存==

    1. 强缓存:不会向服务器发送请求,直接从缓存中读取资源,在chrome控制台的network选项中可以看到该请求返回200的状态码,并且size显示from disk cache或from memory cache;

      • Expires:response header里的过期时间,浏览器再次加载资源时,如果在这个过期时间之内,则命中强缓存。

      • Cache-Control:当值设为max-age=300时,则代表在这个请求正确返回时间(浏览器也会记录下来)的5分钟内再次加载资源,则命中强缓存。

        Expires和Cache-Control: max-age=..的作用是差不多的,区别在于Expires是http1.0的产物,Cache-Control是http1.1的产物,两者共存下,Cache_Control的优先级高于Expires;在某些不支持HTTP1.1的环境下,Expires就会发挥用处。所以Expires其实是过时的产物,现阶段它的存在只是一种兼容性的写法。

        还有一个区别是Expires是一个具体的服务器时间,这就导致一个问题,如果客户端时间和服务器时间相差较大,缓存命中与否就不是开发者所期望的。Cache-Control是一个时间段,控制就比较容易。

    2. 协商缓存:向服务器发送请求,服务器会根据这个请求的request header的一些参数来判断是否命中协商缓存,如果命中,则返回304状态码并带上新的response header通知浏览器从缓存中读取资源;

      • Etag(res)和if-None-Match(req): Etag是上一次加载资源时,服务器返回的response header,是对该资源的一种唯一标识,只要资源有变化,Etag就会重新生成。浏览器在下一次加载资源向服务器发送请求时,会将上一次返回的Etag值放到request header里的if-None-Match里,服务器接收后对比资源文件的Etag值做比较,相同表示资源文件没有发生改变,命中协商缓存。

      • Last-Modified(res)和If-Modified-Since(req):Last-Modified是该资源文件最后一次更改时间,服务器会在response header里返回,同时浏览器会把这个值保存起来,在下一次请求时,放在request header里的if-Modified-Since里,服务器在接收到后也会做比对,如果相同则命中协商缓存。

        精度上区别:Etag由于Last-Modified。Last-Modified的时间单位是秒,如果某个文件在1秒内改变了多次,那么他们的Last-Modified其实并没有体现出来修改,但是Etag每次都会改变确保了精度;如果是负载均衡的服务器,各个服务器生成的Last-Modified也有可能不一致。

        性能上区别:Etag要逊于Last-Modified,毕竟Last-Modified只需要记录时间,而Etag需要服务器通过算法来计算出一个hash值。

        优先级上区别,服务器校验优先考虑Etag

      两者的共同点是,都是从客户端缓存中读取资源;区别是强缓存不会发请求,协商缓存会发请求。

  • 缓存位置

    1. Service Worker:是运行在浏览器背后的独立线程,一般可以用来实现缓存功能。因为Service Worker中涉及到请求拦截,所以必须使用HTTPS协议保障安全。

      Service Worker的缓存与浏览器其他内建的缓存机制不同,它可以让我们自由控制缓存那些文件、如何匹配缓存、如何读取缓存、并且缓存是持续性的。

    2. Memory Cache:Memory Cache也就是内存中的缓存,主要包括的是当前中页面中已经抓取到的资源,例如页面上已经下载的样式、脚本、图片等。读取内存中的数据比磁盘高效,可是缓存持续性很短,会随着进程的释放而释放。一旦我们关闭tab页面,内存中的缓存也就被释放了。

      内存缓存在缓存资源时并不关心返回资源的HTTP缓存头Cache-Control是什么值,同时资源的匹配也并非仅仅是对URL做匹配,还可能会对Content-Type,CORS等其他特征做校验。

    3. Disk Cache:Disk Cache也就是存储在硬盘上的缓存,读取速度慢点,但是什么都能存储到磁盘中,时效性和容量上更好。

      对于大文件来说,大概率是不存储到内存中,反之优先。

      当前系统内存使用率高的话,文件也优先存储到硬盘。

    4. Push Cache:(推送缓存)是HTTP/2中的内容,当以上三中缓存都没有命中时,它才会被使。它只在会话(Session)中存在,一旦会话结束就被释放,并且缓存时间也很短暂,在Chrome浏览器中只有5分钟左右,同时它也并非严格执行HTTP头中的缓存指令。

      • 所有的资源都能被推送,并且能够被缓存,但是 Edge 和 Safari 浏览器支持相对比较差。
      • 可以推送 no-cache 和 no-store 的资源。
      • 一旦连接被关闭,Push Cache 就被释放。
      • 多个页面可以使用同一个HTTP/2的连接,也就可以使用同一个Push Cache。这主要还是依赖浏览器的实现而定,出于对性能的考虑,有的浏览器会对相同域名但不同的tab标签使用同一个HTTP连接。
      • Push Cache 中的缓存只能被使用一次。
      • 浏览器可以拒绝接受已经存在的资源推送。
      • 你可以给其他域名推送资源。
  • 用户行为对浏览器缓存的控制

    1. 地址栏访问,链接跳转是正常用户行为,将会触发浏览器缓存机制;
    2. F5刷新,浏览器会设置max—age=0,跳过强缓存判断,会进行协商缓存判断;
    3. ctrl+F5刷新,跳过强缓存和协商缓存,直接从服务器拉取资源。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容