HTTP 缓存机制

为了提高浏览器 HTTP 请求的性能,在 HTTP 协议中有几种缓存机制来保证网络访问的性能。HTTP 协议中提供了如下几种缓存:Cache-Control、Expires、Last-modified 和 ETag,很好的利用它们可以提高我们网站的速度。

Expires

Expires 类似于 Cache-Control 中的 max-age,它告诉浏览器在这个时间(例如:Last-Modified:Sat, 25 Jun 2016 02:26:30 GMT)内直接从本地读取资源,不必再次向服务器请求。

Cache-Control

它用于定义资源的缓存策略,可以设置以下值:

  • no-store:绝对禁止缓存,每次请求支援都要从服务器端获取;
  • no-cache
  • publice:允许代理服务器缓存资源;
  • private:不允许代理服务器缓存资源;
  • max-age:设置缓存的最大有效时间(单位:秒),当发送请求的时间在有效期范围内,它不会向服务器发送请求,直接从本地获取资源。当它与 Expries 缓存同时使用时,Expries 失效;
  • s-maxage:类似于 max-age,只适用于 publice` 缓存,一般用在 CDN 服务器上;

当 Expires 和 max-age 同时存在时,Expires 将被忽略。

Last-modified

Last-modified 是服务器端返回给浏览器资源的最后修改时间。如果同样一个资源的最后修改时间有变动,服务器会返回给浏览器 200 告诉浏览器需要重新向服务器请求新资源;如果没有变动,服务器会返回浏览器 304 告诉浏览器资源没有变动,直接从本地读取。

ETag

ETag 是为了解决 Last-modified 的一些缺陷:

  • 一些资源的最后修改时间变了,但是内容没有改变;
  • Last-modified 只能精确到秒级;

这样我们引入了 ETag,服务端会通过资源文件生成一段 Hash 字符串来标示这个资源,在 HTTP 的头部会将此标示返回给浏览器端,同时浏览器每次请求会将 ETag 发送给服务器端,此刻服务器端会比较请求和和即将返回的资源的 ETag,如果不一样,服务器会返回给浏览器 200 告诉浏览器需要重新向服务器请求新资源;如果一样,服务器会返回浏览器 304 告诉浏览器资源没有变动,直接从本地读取。

当 Etag 和 Last-modified 同时存在时,Last-modified 会忽略。

它们的区别

为什么有这么多缓存呢,其实它们是存在区别的:Expires 以及 Cache-Control 两种缓存在有效期内,它们是不会向服务器端发送任何请求的,直接获取本地资源;然而 Last-modified 和 ETag 还是需要请求服务器,服务器比较完后高速浏览器是否需要从本地获取。

这几种缓存需要搭配使用,如果客户端的有效期失效后,再次访问服务器端让服务器端比较一下资源内容是否改变,如果改变了这样服务器端才返回最新资源。

对于不同的资源的缓存策略

不同类型的资源会采用不同的缓存策略,通常 html 文件经常会采用 Cache-Control:no-cache,css 和 js 文件通常会采用 Cache-Control:max-age

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,240评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,328评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,182评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,121评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,135评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,093评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,013评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,854评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,295评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,513评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,398评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,989评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,636评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,657评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352

推荐阅读更多精彩内容

  • HTTP报文就是浏览器和服务器间通信时发送及响应的数据块。 浏览器向服务器请求数据,发送请求(request)报文...
    ch1n3h阅读 343评论 0 0
  • 重点参考: 浏览器 HTTP 协议缓存机制详解 https://www.cnblogs.com/520yang/a...
    Kevin_Junbaozi阅读 443评论 0 1
  • 简介 web缓存大致可以分为:数据库缓存,服务器端缓存(代理服务器缓存,CDN缓存),浏览器缓存。浏览器缓存也包含...
    我向你奔阅读 492评论 0 1
  • 1. 思路1,无缓存 浏览器向服务器请求资源 a.jpg,服务器找到对应资源把内容返回给浏览器。当浏览器再次向服务...
    蔡华鹏阅读 563评论 0 0
  • HTTP 缓存到底怎么实现呢?之前课堂上讲过怎么突然想不起来了... 从头开始捋一捋吧!一、 思路1,无缓存浏览器...
    IrisLong阅读 144评论 0 0