對http緩存機(jī)制的理解

先用一張圖來展示瀏覽器緩存機(jī)制:

瀏覽器緩存分兩種:強(qiáng)制緩存和協(xié)商緩存逢唤。

強(qiáng)制緩存

強(qiáng)制緩存主要是通過Expires和Cache-Control掐松。

Cache-Control字段

cache-control: no-store:不緩存侮腹,這個(gè)會(huì)讓客戶端缓苛、服務(wù)器都不緩存嘴纺,也就沒有所謂的強(qiáng)緩存几睛、協(xié)商緩存了房轿。

cache-control: no-cache:協(xié)商緩存

cache-control: max-age=xxxx,private:只允許客戶端可以緩存該資源;代理服務(wù)器不允許緩存囱持;客戶端在xxx秒內(nèi)直接讀取緩存, statu code: 200

cache-control: max-age=xxxx夯接,public:客戶端和代理服務(wù)器都可以緩存該資源;客戶端在xxx秒的有效期內(nèi)纷妆,如果有請求該資源的需求的話就直接讀取緩存, statu code: 200盔几;

所以想設(shè)置強(qiáng)制緩存,可通過設(shè)置cache-control字段:

cache-control: max-age=xxxx掩幢,private

或者

cache-control: max-age=xxxx逊拍,s-maxage=xxx,public

max-age,s-maxage設(shè)置的是相對時(shí)間际邻,s-maxage多用于公共緩存服務(wù)器

用戶操作瀏覽器的行為也會(huì)決定cache-control有沒有效果

還可以通過設(shè)置Expires:xxxx芯丧,expires設(shè)置的是絕對時(shí)間

協(xié)商緩存

當(dāng)服務(wù)器響應(yīng)頭cache-control: no-cache,或者設(shè)置強(qiáng)緩存但是當(dāng)緩存過期之后世曾,未必緩存就不能使用缨恒,所以要和服務(wù)器協(xié)商判斷緩存是否能使用,這些情況都涉及到協(xié)商緩存轮听。

協(xié)商緩存通過Etag/If-None-Match,last-Modified/If-Modified-Since骗露。

Etag/If-None-Match:

都是服務(wù)器為資源分配到唯一標(biāo)識(shí)。當(dāng)客戶端請求資源時(shí)血巍,服務(wù)器會(huì)在http響應(yīng)頭設(shè)置Etag椒袍,資源變化Etag也會(huì)隨之變化。再次請求資源時(shí)藻茂,請求頭帶上If-None-Match。如果Etag和If-None-Match一致玫恳,則返回狀態(tài)碼為304的響應(yīng)辨赐,繼續(xù)使用緩存。如果不一致則獲取更新后的資源返回給前端京办。

last-Modified/If-Modified-Since:

文件的修改時(shí)間(絕對時(shí)間)掀序,精確到秒。

當(dāng)客戶端請求資源時(shí)惭婿,服務(wù)器會(huì)在http響應(yīng)頭設(shè)置last-Modified不恭,資源變化last-Modified也會(huì)隨之變化。再次請求資源時(shí)财饥,請求頭帶上If-Modified-Since换吧,如果last-Modified和If-Modified-Since一致,則返回狀態(tài)碼為304的響應(yīng)钥星,繼續(xù)使用緩存沾瓦。如果不一致則獲取更新后的資源返回給前端。

Etag/If-None-Match較之 last-Modified/If-Modified-Since的優(yōu)勢:

a、last-Modified精確到的時(shí)間是秒贯莺,所以如果資源在秒內(nèi)即是變化了last-Modified也不會(huì)改變风喇,那么其實(shí)協(xié)商緩存判斷的結(jié)果就不準(zhǔn)確了。

b缕探、一些服務(wù)器的資源可能會(huì)周期性的更改魂莫,但是其實(shí)內(nèi)容是沒有變的,但last-Modified變了爹耗,就得重新從服務(wù)器加載資源耙考。

c、某些服務(wù)器不能精確的得到服務(wù)器的修改時(shí)間鲸沮。

緩存機(jī)制的應(yīng)用場景

讀多寫少的數(shù)據(jù)琳骡。

備注:如有不準(zhǔn)確,后續(xù)會(huì)進(jìn)行改進(jìn)讼溺。參考文章https://www.cnblogs.com/cckui/p/11506514.html楣号、https://segmentfault.com/a/1190000015816331、https://www.cnblogs.com/skylar/p/browser-http-caching.html



最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末怒坯,一起剝皮案震驚了整個(gè)濱河市炫狱,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌剔猿,老刑警劉巖视译,帶你破解...
    沈念sama閱讀 211,817評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異归敬,居然都是意外死亡酷含,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評論 3 385
  • 文/潘曉璐 我一進(jìn)店門汪茧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來椅亚,“玉大人,你說我怎么就攤上這事舱污⊙教颍” “怎么了?”我有些...
    開封第一講書人閱讀 157,354評論 0 348
  • 文/不壞的土叔 我叫張陵扩灯,是天一觀的道長媚赖。 經(jīng)常有香客問我,道長珠插,這世上最難降的妖魔是什么惧磺? 我笑而不...
    開封第一講書人閱讀 56,498評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮捻撑,結(jié)果婚禮上豺妓,老公的妹妹穿的比我還像新娘惜互。我一直安慰自己,他們只是感情好琳拭,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評論 6 386
  • 文/花漫 我一把揭開白布训堆。 她就那樣靜靜地躺著,像睡著了一般白嘁。 火紅的嫁衣襯著肌膚如雪坑鱼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,829評論 1 290
  • 那天絮缅,我揣著相機(jī)與錄音鲁沥,去河邊找鬼。 笑死耕魄,一個(gè)胖子當(dāng)著我的面吹牛画恰,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播吸奴,決...
    沈念sama閱讀 38,979評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼允扇,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了则奥?” 一聲冷哼從身側(cè)響起考润,我...
    開封第一講書人閱讀 37,722評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎读处,沒想到半個(gè)月后糊治,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,189評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡罚舱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評論 2 327
  • 正文 我和宋清朗相戀三年井辜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片管闷。...
    茶點(diǎn)故事閱讀 38,654評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡抑胎,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出渐北,到底是詐尸還是另有隱情,我是刑警寧澤铭拧,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布赃蛛,位于F島的核電站,受9級特大地震影響搀菩,放射性物質(zhì)發(fā)生泄漏呕臂。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評論 3 313
  • 文/蒙蒙 一肪跋、第九天 我趴在偏房一處隱蔽的房頂上張望歧蒋。 院中可真熱鬧,春花似錦、人聲如沸谜洽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽阐虚。三九已至序臂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間实束,已是汗流浹背奥秆。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留咸灿,地道東北人构订。 一個(gè)月前我還...
    沈念sama閱讀 46,382評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像避矢,于是被迫代替她去往敵國和親悼瘾。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評論 2 349