国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

web性能優化之:no-cache與must-revalidate深入探究

alexnevsky / 3414人閱讀

摘要:本文僅挑這兩個進行值進行探究對比。注意變化了,表示源服務器資源已發生變化。從日志來看,緩存服務器訪問源服務器,并返回給瀏覽器。緩存服務器上已有該資源副本,且該副本未過期。緩存服務器本身優化算法對實驗結果的影響。

引言

稍微了解HTTP協議的前端同學,想必對Cache-Control不會感到陌生,性能優化時經常都會跟它打交道。

常見的值有有privatepublic、no-store、no-cache、must-revalidate、max-age等。

各個取值所代表的含義,網上總結挺多的,這里就不打算再進行逐一介紹,感興趣的可以一起探討交流。

本文僅挑no-cache、must-revalidate 這兩個進行值進行探究對比。在項目實踐中,這兩個值用的比較多,也比較容易搞混。

Cache-Control: no-cache
Cache-Control: max-age=60, must-revalidate

傳送門:RFC2616關于Cache-Control首部的介紹。

no-cache、must-revalidate簡介

no-cache: 告訴瀏覽器、緩存服務器,不管本地副本是否過期,使用資源副本前,一定要到源服務器進行副本有效性校驗。

must-revalidate:告訴瀏覽器、緩存服務器,本地副本過期前,可以使用本地副本;本地副本一旦過期,必須去源服務器進行有效性校驗。

上面的介紹涉及三個主體:瀏覽器緩存服務器、源服務器。下面小節會簡單進行介紹。

瀏覽器、緩存服務器、源服務器

瀏覽器:資源請求直接發起方。

源服務器:資源實際提供方。

緩存服務器:在瀏覽器、源服務器之間架設的中間服務器,由它代替瀏覽器,向源服務器發起資源請求;

緩存服務器作用如下。緩存服務器不是必須的,瀏覽器可也可與源服務器直接通信。

加速資源訪問速度,降低源服務器的負載。緩存服務器從源服務器獲取資源,并返回給瀏覽器。此外,緩存服務器一般還會在本地保存資源的副本,當有相同的資源請求到來,緩存服務器可返回資源副本,以此提高資源訪問速度。

對比測試場景、環境準備 對比測試場景

下文會通過以下兩種場景的對比測試,來探究no-cachemust-revalidate的區別。

瀏覽器 直接訪問 源服務器。

瀏覽器 通過 緩存服務器,間接訪問 源服務器。

環境準備

操作系統:OSX 10.11.4

瀏覽器:Chrome 52.0.2743.116 (64-bit)、Firefox 49.0.2

緩存服務器:Squid 3.6

源服務器:Express 4.14.0

1、下載實驗代碼:可以訪問github主頁獲取,也可通過git clone下載到本地。

git clone https://github.com/chyingp/tech-experiment.git
cd tech-experiment/2016.10.25-cache-control/
npm install

2、安裝Squid,步驟略,下載地址。

3、可選:啟動Squid,并將本地http代理設置為Squid的ip和端口。

備注:測試場景“通過緩存服務器,間接訪問源服務器資源”時,才需要這一步。

4、可選:將本地代理設置為Charles的地址,然后將Charles的代理地址設置為squid的代理地址。(避免瀏覽器開發者工具對request header的修改,干擾實驗結果)

場景一:瀏覽器->源服務器

首先,通過以下腳本啟動本地服務器(源服務器)。

cd connect-directly 
node server.js 
Cache-Control: no-cache

用例1:二次訪問,源服務器 上 資源 未發生變化

訪問地址為:http://127.0.0.1:3000/no-cache

步驟一:第一次訪問,返回內容如下??梢钥吹?,返回了Cache-Control: no-cache

HTTP/1.1 200 OK
X-Powered-By: Express
Cache-Control: no-cache
Content-Type: text/html; charset=utf-8
Content-Length: 11
ETag: W/"b-s0vwqaICscfrawwztfPIiA"
Date: Wed, 26 Oct 2016 07:46:28 GMT
Connection: keep-alive

步驟二:第二次訪問,返回內容如下。返回狀態碼為304 Not Modified,表示經過校驗,源服務器上的資源沒有變化,瀏覽器可以采用本地副本。

HTTP/1.1 304 Not Modified
X-Powered-By: Express
Cache-Control: no-cache
ETag: W/"b-s0vwqaICscfrawwztfPIiA"
Date: Wed, 26 Oct 2016 07:47:31 GMT
Connection: keep-alive

用例2:二次訪問,源服務器 上 資源 發生變化

步驟一:訪問地址為:http://127.0.0.1:3000/no-cach...
備注:change=1告訴源服務器,每次訪問都返回不同內容

步驟一:第一次訪問,內容如下,不贅述。

HTTP/1.1 200 OK
X-Powered-By: Express
Cache-Control: no-cache
Content-Type: text/html; charset=utf-8
Content-Length: 11
ETag: W/"b-8n8r0vUN+mIIQCegzmqpuQ"
Date: Wed, 26 Oct 2016 07:48:01 GMT
Connection: keep-alive

步驟二:第二次訪問,返回內容如下。注意Etag變化了,表示源服務器資源已發生變化。于是狀態碼為200 OK,源服務器返回新版本的資源給瀏覽器。

HTTP/1.1 200 OK
X-Powered-By: Express
Cache-Control: no-cache
Content-Type: text/html; charset=utf-8
Content-Length: 11
ETag: W/"b-0DK7Mx61dfZc1vIPJDSNSQ"
Date: Wed, 26 Oct 2016 07:48:38 GMT
Connection: keep-alive
Cache-Control: must-revalidate

訪問地址:http://127.0.0.1:3000/must-re...
可選參數說明:

max-age:源站返回的內容,max-age是多少(單位是s)。

change:源站返回的內容,是否變化,如果是1,則變化。

用例1:二次訪問,瀏覽器緩存未過期

訪問地址:http://127.0.0.1:3000/must-re...
備注:max-age=10表示,希望資源緩存10s

步驟一:第一次訪問,返回內容如下。

HTTP/1.1 200 OK
X-Powered-By: Express
Cache-Control: max-age=10, must-revalidate
Content-Type: text/html; charset=utf-8
Content-Length: 16
ETag: W/"10-dK948plT5cojN3y7Cy717w"
Date: Wed, 26 Oct 2016 08:06:16 GMT
Connection: keep-alive

步驟二:第二次訪問(在10s內),如下截圖所示,瀏覽器直接從本地緩存里讀取資源副本,并沒有重新發起HTTP請求。

用例2:二次訪問,瀏覽器緩存已過期,源服務器 資源未變化

步驟一:第一次訪問略過。第二次訪問如下截圖所示(10s后),返回304 Not Modified

HTTP/1.1 304 Not Modified
X-Powered-By: Express
Cache-Control: max-age=10, must-revalidate
ETag: W/"10-dK948plT5cojN3y7Cy717w"
Date: Wed, 26 Oct 2016 08:09:22 GMT
Connection: keep-alive

用例3:瀏覽器緩存已過期,源服務器 資源 已變化

訪問地址:http://127.0.0.1:3000/must-re...

步驟一:第一次訪問,截圖如下。

步驟二:第二次訪問(10s后),返回截圖如下,可以看到返回了200

場景2:瀏覽器->緩存服務器->源服務器

從上面的對比實驗已經知道,在不經過緩存服務器的情況下,no-cachemust-revalidate在緩存校驗方面的差別。

接下來,我們再看下,引入緩存服務器后,二者表現的差異點。

備注:下文我們會通過查看Squid的訪問日志,來確認緩存服務器的行為。這里對日志中的幾個關鍵字先粗略解釋下:

TCP_MISS:沒有命中緩存。有可能是緩存服務器不存在資源的副本,也有可能資源副本已過期。

TCP_MEM_HIT:命中了緩存。緩存服務器存在資源的副本,并且副本未過期。

再次貼上之前的圖。

Cache-Control: no-cache

用例1:chrome第一次訪問資源

chrome訪問截圖如下:200 ok

squid日志:TCP_MISS,表示沒有命中本地資源副本。

1477501799.573     17 127.0.0.1 TCP_MISS/200 299 GET http://127.0.0.1:3000/no-cache - HIER_DIRECT/127.0.0.1 text/html

用例2:chrome再次訪問該資源。且源服務器上,該資源未變化

訪問地址:http://127.0.0.1:3000/no-cache

第一次訪問略。第二次訪問,chrome訪問截圖如下:

squid訪問日志如下:TCP_MISS/304 。表示緩存服務器 聯系了 源服務器,發現內容沒變化,于是返回304。

1477501987.785      1 127.0.0.1 TCP_MISS/304 238 GET http://127.0.0.1:3000/no-cache - HIER_DIRECT/127.0.0.1 -

用例3:chrome再次訪問該資源。且源服務器上,該資源已變化

訪問地址:http://127.0.0.1:3000/no-cach...
備注:change=1 表示強制每次訪問源服務器,返回的資源都是新的。

第一次訪問略。第二次訪問,chrome截圖如下,狀態碼為200。

從squid日志來看,緩存服務器 訪問 源服務器,并返回200給瀏覽器。

1477647837.216      1 127.0.0.1 TCP_MISS/200 299 GET http://127.0.0.1:3000/no-cache? - HIER_DIRECT/127.0.0.1 text/html
Cache-Control: must-revalidate

用例1:緩存服務器 已存在 資源副本,且該資源副本 未過期

訪問地址:http://127.0.0.1:3000/must-re...
備注:max-age=900表示資源有效期是900s

步驟一:

chrome第一次訪問 該資源,緩存服務器上沒有該資源副本,于是訪問源服務器。最終,緩存服務器給瀏覽器返回200。此時,緩存服務器squid上有了資源的副本。

步驟二:

firefox第一次訪問 該資源(900s內)。緩存服務器上已有該資源副本,且該副本未過期。于是,緩存服務器給firefox返回該資源副本,且狀態碼為200。(緩存命中)

為了驗證步驟二中,緩存服務器 返回的是本地資源的副本,查看squid日志。其中,第二條就是firefox的訪問記錄,TCP_MEM_HIT/200表示命中本地緩存。

1477648947.594      5 127.0.0.1 TCP_MISS/200 325 GET http://127.0.0.1:3000/must-revalidate? - HIER_DIRECT/127.0.0.1 text/html
1477649012.625      0 127.0.0.1 TCP_MEM_HIT/200 333 GET http://127.0.0.1:3000/must-revalidate? - HIER_NONE/- text/html

用例2:緩存服務器 已存在 資源副本,該資源副本已過期,但源服務器上 資源未改變

訪問鏈接:http://127.0.0.1:3000/must-re...

用chrome先后訪問該資源,其間間隔超過10s。第二次訪問時,chrome收到響應如下。

查看squid日志??梢钥吹?,狀態為TCP_MISS/304,表示本地副本已過期,跟源服務器進行校驗,發現源服務器上資源未改變。于是,給瀏覽器返回304。

1477649429.105     11 127.0.0.1 TCP_MISS/304 258 GET http://127.0.0.1:3000/must-revalidate? - HIER_DIRECT/127.0.0.1 -

用例3:緩存服務器 已存在 資源副本,該資源副本 已過期,但源服務器上 資源已改變

訪問地址:http://127.0.0.1:3000/must-re...

用chrome先后訪問該資源,其間間隔超過10s。第二次訪問時,chrome收到響應如下

squid日志如下,狀態都是TCP_MISS/200,表示沒有命中緩存。

1477650702.807      8 127.0.0.1 TCP_MISS/200 325 GET http://127.0.0.1:3000/must-revalidate? - HIER_DIRECT/127.0.0.1 text/html

1477651020.516      4 127.0.0.1 TCP_MISS/200 325 GET http://127.0.0.1:3000/must-revalidate? - HIER_DIRECT/127.0.0.1 text/html
對比結論

以下針對的都是瀏覽器第n次訪問資源。(n>1)

不考慮緩存服務器
首部 本地緩存是否過期 源服務器資源是否改變 是否重新校驗 狀態碼
no-cache 不確定 304
no-cache 不確定 200
must-revalidate 是/否 200(來自瀏覽器緩存)
must-revalidate 304
must-revalidate 200
考慮緩存服務器
首部 本地緩存是否過期 緩存服務器副本是否過期 源服務器資源是否改變 是否重新校驗 狀態碼
no-cache 不確定 不確定 304
no-cache 不確定 不確定 200
must-revalidate 是/否 是/否 200(來自瀏覽器緩存)
must-revalidate 是/否 304(來自緩存服務器)
must-revalidate 304
must-revalidate 200
寫在后面

經過一輪對比測試,發現no-cache、must-revalidate這兩個值還是蠻有意思的。實際上,由于篇幅原因,這里還有一些內容尚未進行對比實驗。比如:

must-revalidateno-cachemax-stale一起使用時的表現。

no-cachemax-age=0, mustvalidate的區別。

no-chche制定具體的字段名時,跟不指明具體字段名時,緩存校驗行為上的區別。

proxy-revalidatemust-revalidate的區別。

緩存服務器本身優化算法對實驗結果的影響。

對比實驗過程比較枯燥繁瑣,如有不嚴謹或錯漏的地方,敬請指出 :)

這里留個經常會碰到的問題,供讀者探討:no-cachemax-age=0, mustvalidate的區別。

相關鏈接

RFC2616 14.9: Cache-Control
https://www.w3.org/Protocols/...

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/61829.html

相關文章

  • WEB緩存探究

    摘要:為了提升網站性能,有效利用緩存能夠提升用戶體驗,提高訪問效率。同時不要忘記給文件名加上指紋,以便及時更新改動同樣設置為年后到期,但標記為,因為它可能會包含某些用戶私人數據,這是不應緩存的。圖像緩存時不包含版本或唯一指紋,并設置為天后到期。 前言 由于項目越來越大,即使了使用代碼壓縮工具減少文件大小,js文件還是不可避免的越變越大。而對于用戶來說每次重新下載都有可能會消耗大量時間,讓我們...

    dongxiawu 評論0 收藏0
  • WEB緩存探究

    摘要:為了提升網站性能,有效利用緩存能夠提升用戶體驗,提高訪問效率。同時不要忘記給文件名加上指紋,以便及時更新改動同樣設置為年后到期,但標記為,因為它可能會包含某些用戶私人數據,這是不應緩存的。圖像緩存時不包含版本或唯一指紋,并設置為天后到期。 前言 由于項目越來越大,即使了使用代碼壓縮工具減少文件大小,js文件還是不可避免的越變越大。而對于用戶來說每次重新下載都有可能會消耗大量時間,讓我們...

    Simon_Zhou 評論0 收藏0
  • WEB緩存探究

    摘要:為了提升網站性能,有效利用緩存能夠提升用戶體驗,提高訪問效率。同時不要忘記給文件名加上指紋,以便及時更新改動同樣設置為年后到期,但標記為,因為它可能會包含某些用戶私人數據,這是不應緩存的。圖像緩存時不包含版本或唯一指紋,并設置為天后到期。 前言 由于項目越來越大,即使了使用代碼壓縮工具減少文件大小,js文件還是不可避免的越變越大。而對于用戶來說每次重新下載都有可能會消耗大量時間,讓我們...

    chaosx110 評論0 收藏0
  • 瀏覽器的緩存(1)

    摘要:當然,緩存不止這一種,比如在中定義的某些也可以實現自定義緩存的但,實際情況是,這些只能在本地文件中使用,如果是服務器則默認被覆蓋。 親,你知道緩存是什么嗎? 其實緩存就像辦健身卡,我第一次花了699辦了一年的卡之后,接下來的一年我都可以免費鍛煉。 在web 中, 我們交的不是錢,而是空間,我們耗費一定的空間之后,能夠獲得網頁打開速度質的飛躍。 當我們第一次訪問一個頁面時,我們需要交納一...

    dayday_up 評論0 收藏0

發表評論

0條評論

alexnevsky

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<