終于有人把HTTP講的一清二楚了——緩存篇
概述
HTTP協(xié)議的緩存是通過6個報文頭完成的,通過兩層協(xié)商使web資源能夠不那么頻繁地在服務(wù)器與客戶端之間傳遞,從而節(jié)約了流量,提高瀏覽速度。以從客戶端到服務(wù)器的順序,第一層協(xié)商為Cache-Control與Expires;第二層協(xié)商為Last-Modified與Etag。
相關(guān)的報文頭
Cache-Control
請求/響應(yīng)報文頭,緩存控制字段,也就是用于給資源生命期,是http/1.1引入的屬性。Cache-Control的取值可細(xì)分為兩類,一類是對緩存有直接決定性的值,他們會導(dǎo)致后續(xù)的第二層協(xié)商被跳過,包括:no-store、public、private;另一類是類似Expires的值,只是規(guī)定了有效期,后續(xù)的第二層協(xié)商不受影響,包括no-cache、max-age=x、s-maxage=x。
Cache-Control的取值如下:

形如:
- Cache-Control:max-age=0
Expires
響應(yīng)報文頭,代表資源過期時間,由服務(wù)器返回提供,是http1.0的屬性,在與Cache-Control共存的情況下,優(yōu)先級要低。Expires的功能基本與Cache-Control的max-age相似,但它是指定一個過期時間點(diǎn),而Cache-Control的max-age是指定了過期前的秒數(shù)。
形如:
- Expires:Fri, 10 Apr 2020 16:30:04 GMT
Last-Modified
響應(yīng)報文頭,資源最新修改時間,由服務(wù)器告訴瀏覽器。
形如:
- Last-Modified:Mon, 23 Mar 2020 18:39:50 GMT
If-Modified-Since
請求報文頭,與Last-Modified相對應(yīng),瀏覽器把服務(wù)器最后一次給的Last-Modified返回,服務(wù)器將以此進(jìn)行對比,判斷資源是否需要更新。
形如:
- If-Modified-Since:Fri, 10 Apr 2020 14:45:24 GMT
Etag
響應(yīng)報文頭,資源內(nèi)容唯一標(biāo)識,由服務(wù)器告訴瀏覽器。
形如:
- Etag:58b66ccbe349d0d931df877c00d8101d037243dc
If-None-Match
請求報文頭,與Etag相對應(yīng),瀏覽器把服務(wù)器最后一次給的Etag返回,服務(wù)器將以此進(jìn)行對比,判斷資源是否需要更新。
形如:
- If-None-Match:58b66ccbe349d0d931df877c00d8101d037243dc
協(xié)商流程
以下假定資源已經(jīng)獲取過一次,并且運(yùn)行在HTTP/1.1環(huán)境下,現(xiàn)在進(jìn)行二次訪問。
流程圖如下:

說明:
- 客戶端是有可能因?yàn)榫彺嬖虿幌蚍?wù)器發(fā)起任何請求的,圖中200狀態(tài)(from cache)就是這種情況。
- 服務(wù)器根據(jù)回傳的If-Modified-Since與Last-Modified比對,如果不同則說明這個文件修改過,需要更新。但在這種判斷精度是秒,如果是一秒內(nèi)的改動,就需要進(jìn)一步對比回傳的If-None-Match與ETag的值。
- 服務(wù)器返回304的意思就是不需要重新獲取新資源,直接使用本地緩存即可。
緩存多久合適
生存時間(TTL)指令告訴瀏覽器應(yīng)該緩存某個資源多久,即Cache-Control或Expires的值。找到給定資源的最佳TTL值并沒有完美的科學(xué)方法,只能憑經(jīng)驗(yàn)給出一些指導(dǎo)原則。
指導(dǎo)原則:
- 純靜態(tài)內(nèi)容,例如圖片或帶版本的數(shù)據(jù),可以在客戶端永久緩存;
- CSS/JS和個性化資源,緩存時間大約是會話(交互)平均時間的兩倍;
- 其他類型資源取決于新數(shù)據(jù)對舊數(shù)據(jù)的容忍極限。
瀏覽器操作對HTTP緩存的影響

緩存改進(jìn)方案
md5/hash緩存:通過不緩存html,為靜態(tài)文件添加MD5或者h(yuǎn)ash標(biāo)識,解決瀏覽器無法跳過緩存過期時間主動感知文件變化的問題。
CDN緩存:CDN是構(gòu)建在網(wǎng)絡(luò)之上的內(nèi)容分發(fā)網(wǎng)絡(luò),依靠部署在各地的邊緣服務(wù)器,通過中心平臺的負(fù)載均衡、內(nèi)容分發(fā)、調(diào)度等功能模塊,使用戶就近獲取所需內(nèi)容,降低網(wǎng)絡(luò)擁塞,提高用戶訪問響應(yīng)速度和命中率。