HTTP緩存機(jī)制

Web 緩存大致可以分為:數(shù)據(jù)庫(kù)緩存、服務(wù)器端緩存(代理服務(wù)器緩存完域、CDN 緩存)昼浦、瀏覽器緩存。

瀏覽器緩存也包含很多內(nèi)容: HTTP 緩存筒主、indexDB关噪、cookie、localstorage 等等乌妙。

瀏覽器緩存分為強(qiáng)緩存和協(xié)商緩存使兔,瀏覽器加載一個(gè)頁(yè)面的簡(jiǎn)單流程如下:

1.瀏覽器先根據(jù)這個(gè)資源的http頭信息來(lái)判斷是否命中強(qiáng)緩存。如果命中則直接加在緩存中的資源藤韵,并不會(huì)將請(qǐng)求發(fā)送到服務(wù)器虐沥。
2.如果未命中強(qiáng)緩存,則瀏覽器會(huì)將資源加載請(qǐng)求發(fā)送到服務(wù)器泽艘。服務(wù)器來(lái)判斷瀏覽器本地緩存是否失效欲险。若可以使用,則服務(wù)器并不會(huì)返回資源信息匹涮,瀏覽器繼續(xù)從緩存加載資源天试。
3.如果未命中協(xié)商緩存,則服務(wù)器會(huì)將完整的資源返回給瀏覽器然低,瀏覽器加載新資源喜每,并更新緩存。

強(qiáng)緩存

命中強(qiáng)緩存時(shí)雳攘,瀏覽器并不會(huì)將請(qǐng)求發(fā)送給服務(wù)器带兜。在Chrome的開(kāi)發(fā)者工具中看到http的返回碼是200,但是在Size列會(huì)顯示為(from cache)吨灭。
強(qiáng)緩存是利用http的返回頭中的Expires或者Cache-Control兩個(gè)字段來(lái)控制的刚照,用來(lái)表示資源的緩存時(shí)間。


Expires

緩存過(guò)期時(shí)間喧兄,用來(lái)指定資源到期的時(shí)間无畔,是服務(wù)器端的具體的時(shí)間點(diǎn)。也就是說(shuō)繁莹,Expires=max-age + 請(qǐng)求時(shí)間檩互,需要和Last-modified結(jié)合使用。但在上面我們提到過(guò)咨演,cache-control的優(yōu)先級(jí)更高闸昨。 Expires是Web服務(wù)器響應(yīng)消息頭字段,在響應(yīng)http請(qǐng)求時(shí)告訴瀏覽器在過(guò)期時(shí)間前瀏覽器可以直接從瀏覽器緩存取數(shù)據(jù),而無(wú)需再次請(qǐng)求饵较。



該字段會(huì)返回一個(gè)時(shí)間拍嵌,比如Expires:Thu,31 Dec 2037 23:59:59 GMT。這個(gè)時(shí)間代表著這個(gè)資源的失效時(shí)間循诉,也就是說(shuō)在2037年12月31日23點(diǎn)59分59秒之前都是有效的横辆,即命中緩存。這種方式有一個(gè)明顯的缺點(diǎn)茄猫,由于失效時(shí)間是一個(gè)絕對(duì)時(shí)間狈蚤,所以當(dāng)客戶端本地時(shí)間被修改以后,服務(wù)器與客戶端時(shí)間偏差變大以后划纽,就會(huì)導(dǎo)致緩存混亂脆侮。于是發(fā)展出了Cache-Control。

Cache-Control

Cache-Control是一個(gè)相對(duì)時(shí)間勇劣,例如Cache-Control:3600靖避,代表著資源的有效期是3600秒。由于是相對(duì)時(shí)間比默,并且都是與客戶端時(shí)間比較幻捏,所以服務(wù)器與客戶端時(shí)間偏差也不會(huì)導(dǎo)致問(wèn)題。
Cache-Control與Expires可以在服務(wù)端配置同時(shí)啟用或者啟用任意一個(gè)命咐,同時(shí)啟用的時(shí)候Cache-Control優(yōu)先級(jí)高篡九。
Cache-Control 可以由多個(gè)字段組合而成,主要有以下幾個(gè)取值:

1. max-age

指定一個(gè)時(shí)間長(zhǎng)度侈百,在這個(gè)時(shí)間段內(nèi)緩存是有效的瓮下,單位是s翰铡。例如設(shè)置 Cache-Control:max-age=31536000钝域,也就是說(shuō)緩存有效期為(31536000 / 24 / 60 * 60)天,第一次訪問(wèn)這個(gè)資源的時(shí)候锭魔,服務(wù)器端也返回了 Expires 字段例证,并且過(guò)期時(shí)間是一年后。


在沒(méi)有禁用緩存并且沒(méi)有超過(guò)有效時(shí)間的情況下迷捧,再次訪問(wèn)這個(gè)資源就命中了緩存织咧,不會(huì)向服務(wù)器請(qǐng)求資源而是直接從瀏覽器緩存中取。

  1. s-maxage 同 max-age漠秋,覆蓋 max-age笙蒙、Expires,但僅適用于共享緩存庆锦,在私有緩存中被忽略捅位。

  2. public 表明響應(yīng)可以被任何對(duì)象(發(fā)送請(qǐng)求的客戶端、代理服務(wù)器等等)緩存。

  3. private 表明響應(yīng)只能被單個(gè)用戶(可能是操作系統(tǒng)用戶艇搀、瀏覽器用戶)緩存尿扯,是非共享的,不能被代理服務(wù)器緩存焰雕。

  4. no-cache 強(qiáng)制所有緩存了該響應(yīng)的用戶衷笋,在使用已緩存的數(shù)據(jù)前,發(fā)送帶驗(yàn)證器的請(qǐng)求到服務(wù)器矩屁。不是字面意思上的不緩存辟宗。

  5. no-store 禁止緩存,每次請(qǐng)求都要向服務(wù)器重新獲取數(shù)據(jù)吝秕。

7慢蜓、must-revalidate指定如果頁(yè)面是過(guò)期的,則去服務(wù)器進(jìn)行獲取郭膛。這個(gè)指令并不常用晨抡,就不做過(guò)多的討論了。

協(xié)商緩存

若未命中強(qiáng)緩存则剃,則瀏覽器會(huì)將請(qǐng)求發(fā)送至服務(wù)器耘柱。服務(wù)器根據(jù)http頭信息中的Last-Modify/If-Modify-Since或Etag/If-None-Match來(lái)判斷是否命中協(xié)商緩存。如果命中棍现,則http返回碼為304调煎,瀏覽器從緩存中加載資源。

Last-Modify/If-Modify-Since
ETag/If-None-Match

總結(jié)

瀏覽器第一次發(fā)送請(qǐng)求:


之后再次發(fā)送請(qǐng)求:


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末己肮,一起剝皮案震驚了整個(gè)濱河市士袄,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌谎僻,老刑警劉巖娄柳,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異艘绍,居然都是意外死亡赤拒,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)诱鞠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)挎挖,“玉大人,你說(shuō)我怎么就攤上這事航夺〗抖洌” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵阳掐,是天一觀的道長(zhǎng)始衅。 經(jīng)常有香客問(wèn)我堪伍,道長(zhǎng),這世上最難降的妖魔是什么觅闽? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任帝雇,我火速辦了婚禮,結(jié)果婚禮上蛉拙,老公的妹妹穿的比我還像新娘尸闸。我一直安慰自己,他們只是感情好孕锄,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布吮廉。 她就那樣靜靜地躺著,像睡著了一般畸肆。 火紅的嫁衣襯著肌膚如雪宦芦。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,443評(píng)論 1 302
  • 那天轴脐,我揣著相機(jī)與錄音调卑,去河邊找鬼。 笑死大咱,一個(gè)胖子當(dāng)著我的面吹牛恬涧,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播碴巾,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼溯捆,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了厦瓢?” 一聲冷哼從身側(cè)響起提揍,我...
    開(kāi)封第一講書(shū)人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎煮仇,沒(méi)想到半個(gè)月后劳跃,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡欺抗,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年售碳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绞呈。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖间景,靈堂內(nèi)的尸體忽然破棺而出佃声,到底是詐尸還是另有隱情,我是刑警寧澤倘要,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布圾亏,位于F島的核電站十拣,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏志鹃。R本人自食惡果不足惜夭问,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望曹铃。 院中可真熱鬧缰趋,春花似錦、人聲如沸陕见。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)评甜。三九已至灰粮,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間忍坷,已是汗流浹背粘舟。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留佩研,地道東北人蓖乘。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像韧骗,于是被迫代替她去往敵國(guó)和親嘉抒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • HTTP報(bào)文就是瀏覽器和服務(wù)器間通信時(shí)發(fā)送及響應(yīng)的數(shù)據(jù)塊袍暴。 瀏覽器向服務(wù)器請(qǐng)求數(shù)據(jù)些侍,發(fā)送請(qǐng)求(request)報(bào)文...
    ch1n3h閱讀 343評(píng)論 0 0
  • 首先了解HTTP報(bào)文 HTTP報(bào)文就是瀏覽器和服務(wù)器間通信時(shí)發(fā)送及響應(yīng)的數(shù)據(jù)塊。瀏覽器向服務(wù)器請(qǐng)求數(shù)據(jù)政模,發(fā)送請(qǐng)求(...
    alex夏夜閱讀 1,327評(píng)論 0 4
  • 1. 思路1岗宣,無(wú)緩存 瀏覽器向服務(wù)器請(qǐng)求資源 a.jpg,服務(wù)器找到對(duì)應(yīng)資源把內(nèi)容返回給瀏覽器淋样。當(dāng)瀏覽器再次向服務(wù)...
    蔡華鵬閱讀 563評(píng)論 0 0
  • HTTP 緩存到底怎么實(shí)現(xiàn)呢耗式?之前課堂上講過(guò)怎么突然想不起來(lái)了... 從頭開(kāi)始捋一捋吧!一、 思路1趁猴,無(wú)緩存瀏覽器...
    IrisLong閱讀 144評(píng)論 0 0
  • 2018年10月6日 農(nóng)歷八月二十七 星期六 天氣:晴 讀經(jīng)人:媽媽刊咳、姐姐鈺婷 讀經(jīng)方式:用137累積法 系統(tǒng)...
    香兒蟲(chóng)草醋蛋歸元液閱讀 161評(píng)論 0 0