http緩存

來源: 《http權(quán)威指南》
學(xué)一個(gè)東西,怎么去學(xué)習(xí)呢?
這分為三個(gè)步驟,是什么, 為什么, 怎么做?文章我會(huì)著重講怎么做。

緩存是什么?

web緩存或代理緩存是一種特殊的http代理服務(wù)器, 可以將經(jīng)過代理傳送的常用文檔復(fù)制保存起來。下一個(gè)請求同一文檔的客戶端就可以享受緩存的私有副本所提供的服務(wù)了

緩存有啥子好處??

減少了冗余的數(shù)據(jù)傳輸。

這個(gè)是什么個(gè)玩意呢??
在很多客戶端訪問一個(gè)原始服務(wù)器頁面時(shí),服務(wù)器會(huì)多次傳輸同一份文檔, 每次傳遞給一個(gè)客戶端,一些相同的字節(jié)會(huì)在網(wǎng)絡(luò)中一遍遍傳輸,加重web服務(wù)器的負(fù)載。。有了緩存,就可以保留第一條服務(wù)器響應(yīng)的副本,后繼請求就可以由緩存的副本來應(yīng)付了。

緩解了網(wǎng)絡(luò)瓶頸

很多網(wǎng)絡(luò)為本地網(wǎng)絡(luò)客戶端提供的帶寬比遠(yuǎn)程服務(wù)器提供的帶寬要寬

降低了對原始服務(wù)器的要求

比如在一些爆炸性新聞的時(shí)候,就會(huì)有很多人同時(shí)去訪問一個(gè)服務(wù)器,這個(gè)時(shí)候,服務(wù)器就要處理大量的請求,就可能會(huì)出現(xiàn)災(zāi)難性的崩潰

降低了距離時(shí)延

因?yàn)閺妮^遠(yuǎn)的地方加載頁面會(huì)更慢一些。每臺(tái)網(wǎng)絡(luò)路由器會(huì)都會(huì)增加因特網(wǎng)流量的時(shí)延

好的,現(xiàn)在要開始正式講講我們的緩存了,前面只是小毛皮

緩存處理步驟

1)接收——緩存從網(wǎng)絡(luò)中讀取抵達(dá)的報(bào)文
2)解析——緩存對報(bào)文進(jìn)行,提取出url和各種首部
3)查詢——緩存查看是否有本地副本可用,如果沒有,就獲取一份副本并將其保存在本地。
4)新鮮度查詢——緩存查看已緩存副本是否足夠新鮮,如果不是,就詢問服務(wù)器是否有更新
5)創(chuàng)建響應(yīng)——緩存會(huì)用新的首部和已緩存的主體來構(gòu)建一條響應(yīng)報(bào)文
6)發(fā)送——緩存通過網(wǎng)絡(luò)將響應(yīng)發(fā)回給客戶端
7)日志——緩存可選地創(chuàng)建一個(gè)日志文件條目來描述這個(gè)事務(wù)

緩存GET請求的流程圖

在這里,我們著重了解第(4)步驟
在第四步中的新鮮度查詢中,我們會(huì)了解到一個(gè)文檔過期的概念。

文檔過期

這是通過HTTPCache-Control首部和Expires首部來完成的。這些說明了在多長時(shí)間內(nèi)可以將這些內(nèi)容視為新鮮的。

在緩存文檔過期之前,緩存可以以任意頻率使用這些副本,無需與服務(wù)器聯(lián)系。這個(gè)時(shí)候會(huì)返回帶有200狀態(tài)碼的首部,是一種強(qiáng)緩存的方式。當(dāng)然,除了客戶端請求中包含有阻止提供已緩存或未驗(yàn)證資源的首部。

當(dāng)然,如果文檔過期了呢?
這個(gè)時(shí)候就會(huì)有了服務(wù)器再驗(yàn)證的過程

服務(wù)器再驗(yàn)證
  • 內(nèi)容發(fā)生了變化,緩存就會(huì)獲取一份新的文檔副本,包括一個(gè)新的過期時(shí)間,并將其存儲(chǔ)在舊文檔的位置上,然后將文檔發(fā)送給客戶端,并返回200狀態(tài)碼
  • 內(nèi)容未發(fā)生變化,緩存就只需要獲取新的首部,包括一個(gè)新的過期日期,并對緩存中的首部進(jìn)行更新就可以了,返回304狀態(tài)碼
    那么, 如何進(jìn)行驗(yàn)證呢?
    這里,有兩種再驗(yàn)證方式。If-Modified-Since: <date>, If-None-Match: <tag>, 簡單來說,就是, 一種是通過檢測文檔在指定日期之后是否被修改, 一種是通過服務(wù)器為文檔提供特殊的標(biāo)簽,檢查標(biāo)簽是否被修改。

If-Modified-Since (日期再驗(yàn)證)

這是最常見的緩存再驗(yàn)證首部。即檢查指定時(shí)間之后,文檔是否被修改

If-None-Match (實(shí)體標(biāo)簽再驗(yàn)證)

這里的實(shí)體標(biāo)簽是附加到文檔的任意標(biāo)簽??赡苁前?strong>文檔的序列號(hào)或版本名,或者是文檔內(nèi)容的校驗(yàn)和其他指紋信息。
之后,服務(wù)器就根據(jù)這些實(shí)體標(biāo)簽是否發(fā)生變化來進(jìn)行驗(yàn)證。

為什么會(huì)需要這種驗(yàn)證方式呢??
  • 在某些情況下,文檔可能被修改了, 但所修改的內(nèi)容并不重要,不需要讓世界范圍內(nèi)的緩存都重裝數(shù)據(jù)
  • 有些文檔被周期性的重寫,但實(shí)際包含的數(shù)據(jù)是一樣的,盡管內(nèi)容不變,但修改日期會(huì)發(fā)生變化。

控制緩存的能力

服務(wù)器可以通過HTTP定義的幾種方式來制定文檔過期之前可以將其緩存多久,,大部分來說就是設(shè)置Http首部Cache-Control屬性。

  • Cache-Control: no-store
  • Cache-Control: no-Cache
  • Cache-Control: must-revalidate
  • Cache-Control: max-age
  • Expire日期
  • 不附加過期信息,讓緩存自己確定自己的過期日期

no-store VS no-cache

no-store響應(yīng)會(huì)禁止緩存對響應(yīng)進(jìn)行復(fù)制,緩存通常會(huì)像非緩存代理服務(wù)器一樣,向客戶端發(fā)送一條no-store響應(yīng), 然后刪除對象
no-cache,這個(gè)響應(yīng)實(shí)際上是可以存儲(chǔ)在本地緩存區(qū)的。只是在與原始服務(wù)器進(jìn)行再驗(yàn)證之前,緩存不能將其提供給客戶端使用

max-age響應(yīng)首部

Cache-Control: max-age=3600
Cache-Control: max-age=0 為0時(shí)服務(wù)器可以請求緩存不要存儲(chǔ)文檔,因此每次訪問都進(jìn)行刷新。

must-revalidate響應(yīng)首部

可以配置緩存,使其提供一些陳舊的對象,以提高性能。
Cache-Control: must-revalidate 該響應(yīng)首部告訴緩存,在事先沒有跟原始服務(wù)器進(jìn)行再驗(yàn)證的情況下,不能提供這個(gè)對象的陳舊副本。緩存仍然可以隨意提供新鮮的副本。檢查時(shí)如果原始服務(wù)器不可用就返回504狀態(tài)碼網(wǎng)絡(luò)連接超時(shí)。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 本文內(nèi)容大多參考《圖解HTTP》一書 一. 認(rèn)識(shí)代理服務(wù)器 所以講緩存為什么要先扯代理服務(wù)器?別急,讓我們看一下一...
    流光號(hào)船長閱讀 2,118評論 0 10
  • 網(wǎng)絡(luò)特有的延遲以及數(shù)據(jù)傳輸?shù)某杀荆萍s互聯(lián)網(wǎng)快速獲取Web資源。為此,HTTP協(xié)議引入緩存以空間換時(shí)間,使瀏覽器緩...
    大頭8086閱讀 3,207評論 2 12
  • 每個(gè)瀏覽器都自帶了 HTTP 緩存實(shí)現(xiàn)功能。您只需要確保每個(gè)服務(wù)器響應(yīng)都提供正確的 HTTP 標(biāo)頭指令,以指示瀏覽...
    _july77閱讀 352評論 0 0
  • / 01 / 就在前幾日,有新聞曝出:范冰冰雙喜臨門,不僅接受了李晨的求婚,而且獲得了金雞百花電影節(jié)的最佳女主角,...
    我就是道路閱讀 408評論 0 0
  • 臭撒比兒啊,真稀罕你
    01348557f6f5閱讀 199評論 0 1

友情鏈接更多精彩內(nèi)容