成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

10分鐘徹底搞懂Http的強(qiáng)制緩存和協(xié)商緩存

ThreeWords / 4192人閱讀

摘要:總結(jié)強(qiáng)制緩存只有首次請(qǐng)求才會(huì)跟服務(wù)器通信,讀取緩存資源時(shí)不會(huì)發(fā)出任何請(qǐng)求,資源的狀態(tài)碼為,資源的為或者,版本的實(shí)現(xiàn)優(yōu)先級(jí)會(huì)高于版本的實(shí)現(xiàn)。

一 強(qiáng)制緩存

強(qiáng)制緩存整體流程比較簡單,就是在第一次訪問服務(wù)器取到數(shù)據(jù)之后,在過期時(shí)間之內(nèi)不會(huì)再去重復(fù)請(qǐng)求。實(shí)現(xiàn)這個(gè)流程的核心就是如何知道當(dāng)前時(shí)間是否超過了過期時(shí)間。

強(qiáng)制緩存的過期時(shí)間通過第一次訪問服務(wù)器時(shí)返回的響應(yīng)頭獲取。在 http 1.0http 1.1 版本中通過不同的響應(yīng)頭字段實(shí)現(xiàn)。

http 1.0

http 1.0 版本中,強(qiáng)制緩存通過 Expires 響應(yīng)頭來實(shí)現(xiàn)。 expires 表示未來資源會(huì)過期的時(shí)間。也就是說,當(dāng)發(fā)起請(qǐng)求的時(shí)間超過了 expires 設(shè)定的時(shí)間,即表示資源緩存時(shí)間到期,會(huì)發(fā)送請(qǐng)求到服務(wù)器重新獲取資源。而如果發(fā)起請(qǐng)求的時(shí)間在 expires 限定的時(shí)間之內(nèi),瀏覽器會(huì)直接讀取本地緩存數(shù)據(jù)庫中的信息(from memory or from disk),兩種方式根據(jù)瀏覽器的策略隨機(jī)獲取。

http 1.1

http 1.1 版本中,強(qiáng)制緩存通過 Cache-Control 響應(yīng)頭來實(shí)現(xiàn)。Cache-Control 擁有多個(gè)值:

private:客戶端可以緩存
public:客戶端和代理服務(wù)器均可緩存;
max-age=xxx:緩存的資源將在 xxx 秒后過期;
no-cache:需要使用協(xié)商緩存來驗(yàn)證是否過期;
no-store:不可緩存

最常用的字段就是 max-age=xxx ,表示緩存的資源將在 xxx 秒后過期。一般來說,為了兼容,兩個(gè)版本的強(qiáng)制緩存都會(huì)被實(shí)現(xiàn)。

總結(jié)

強(qiáng)制緩存只有首次請(qǐng)求才會(huì)跟服務(wù)器通信,讀取緩存資源時(shí)不會(huì)發(fā)出任何請(qǐng)求,資源的 Status 狀態(tài)碼為 200,資源的 Sizefrom memory 或者 from disk ,http 1.1 版本的實(shí)現(xiàn)優(yōu)先級(jí)會(huì)高于 http 1.0 版本的實(shí)現(xiàn)。

二 協(xié)商緩存

協(xié)商緩存與強(qiáng)制緩存的不同之處在于,協(xié)商緩存每次讀取數(shù)據(jù)時(shí)都需要跟服務(wù)器通信,并且會(huì)增加緩存標(biāo)識(shí)。在第一次請(qǐng)求服務(wù)器時(shí),服務(wù)器會(huì)返回資源,并且返回一個(gè)資源的緩存標(biāo)識(shí),一起存到瀏覽器的緩存數(shù)據(jù)庫。當(dāng)?shù)诙握?qǐng)求資源時(shí),瀏覽器會(huì)首先將緩存標(biāo)識(shí)發(fā)送給服務(wù)器,服務(wù)器拿到標(biāo)識(shí)后判斷標(biāo)識(shí)是否匹配,如果不匹配,表示資源有更新,服務(wù)器會(huì)將新數(shù)據(jù)和新的緩存標(biāo)識(shí)一起返回到瀏覽器;如果緩存標(biāo)識(shí)匹配,表示資源沒有更新,并且返回 304 狀態(tài)碼,瀏覽器就讀取本地緩存服務(wù)器中的數(shù)據(jù)。

在 http 協(xié)議的 1.01.1 版本中也有不同的實(shí)現(xiàn)方式。

http 1.0

http 1.0 版本中,第一次請(qǐng)求資源時(shí)服務(wù)器通過 Last-Modified 來設(shè)置響應(yīng)頭的緩存標(biāo)識(shí),并且把資源最后修改的時(shí)間作為值填入,然后將資源返回給瀏覽器。在第二次請(qǐng)求時(shí),瀏覽器會(huì)首先帶上 If-Modified-Since 請(qǐng)求頭去訪問服務(wù)器,服務(wù)器會(huì)將 If-Modified-Since 中攜帶的時(shí)間與資源修改的時(shí)間匹配,如果時(shí)間不一致,服務(wù)器會(huì)返回新的資源,并且將 Last-Modified 值更新,作為響應(yīng)頭返回給瀏覽器。如果時(shí)間一致,表示資源沒有更新,服務(wù)器返回 304 狀態(tài)碼,瀏覽器拿到響應(yīng)狀態(tài)碼后從本地緩存數(shù)據(jù)庫中讀取緩存資源。

這種方式有一個(gè)弊端,就是當(dāng)服務(wù)器中的資源增加了一個(gè)字符,后來又把這個(gè)字符刪掉,本身資源文件并沒有發(fā)生變化,但修改時(shí)間發(fā)生了變化。當(dāng)下次請(qǐng)求過來時(shí),服務(wù)器也會(huì)把這個(gè)本來沒有變化的資源重新返回給瀏覽器。

http 1.1

http 1.1 版本中,服務(wù)器通過 Etag 來設(shè)置響應(yīng)頭緩存標(biāo)識(shí)。Etag 的值由服務(wù)端生成。在第一次請(qǐng)求時(shí),服務(wù)器會(huì)將資源和 Etag 一并返回給瀏覽器,瀏覽器將兩者緩存到本地緩存數(shù)據(jù)庫。在第二次請(qǐng)求時(shí),瀏覽器會(huì)將 Etag 信息放到 If-None-Match 請(qǐng)求頭去訪問服務(wù)器,服務(wù)器收到請(qǐng)求后,會(huì)將服務(wù)器中的文件標(biāo)識(shí)與瀏覽器發(fā)來的標(biāo)識(shí)進(jìn)行對(duì)比,如果不相同,服務(wù)器返回更新的資源和新的 Etag ,如果相同,服務(wù)器返回 304 狀態(tài)碼,瀏覽器讀取緩存。

總結(jié)

協(xié)商緩存每次請(qǐng)求都會(huì)與服務(wù)器交互,第一次是拿數(shù)據(jù)和標(biāo)識(shí)的過程,第二次開始,就是瀏覽器詢問服務(wù)器資源是否有更新的過程。每次請(qǐng)求都會(huì)傳輸數(shù)據(jù),如果命中緩存,則資源的 Status 狀態(tài)碼為 304 而不是 200 。同樣的,一般來講為了兼容,兩個(gè)版本的協(xié)商緩存都會(huì)被實(shí)現(xiàn),http 1.1 版本的實(shí)現(xiàn)優(yōu)先級(jí)會(huì)高于 http 1.0 版本的實(shí)現(xiàn)。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/97156.html

相關(guān)文章

  • Http緩存機(jī)制

    摘要:請(qǐng)求過程如下瀏覽器請(qǐng)求靜態(tài)資源服務(wù)器讀取磁盤文件,返給瀏覽器,同時(shí)帶上文件的唯一標(biāo)識(shí)當(dāng)瀏覽器上的緩存文件過期時(shí),瀏覽器帶上請(qǐng)求頭等于上一次請(qǐng)求的請(qǐng)求服務(wù)器服務(wù)器比較請(qǐng)求頭里的和文件的。 前言 Http簡介 瀏覽器和服務(wù)器之間通信是通過HTTP協(xié)議,HTTP協(xié)議永遠(yuǎn)都是客戶端發(fā)起請(qǐng)求,服務(wù)器回送響應(yīng)。模型如下: showImg(https://segmentfault.com/img/b...

    keke 評(píng)論0 收藏0
  • 頁面性能優(yōu)化辦法有哪些?

    摘要:那我們?nèi)绾蝺?yōu)化頁面性能,提高頁面加載速度呢這是本文主要要探討的問題,然而性能優(yōu)化是個(gè)綜合性問題,沒有標(biāo)準(zhǔn)答案,想要面面俱到羅列出來,并非易事。三利用瀏覽器緩存對(duì)于應(yīng)用來說,緩存是提升頁面性能同時(shí)減少服務(wù)器壓力的利器。 引子 互聯(lián)網(wǎng)有一項(xiàng)著名的8秒原則。用戶在訪問Web網(wǎng)頁時(shí),如果時(shí)間超過8秒就會(huì)感到不耐煩,如果加載需要太長時(shí)間,他們就會(huì)放棄訪問。大部分用戶希望網(wǎng)頁能在2秒之內(nèi)就完成加載...

    MageekChiu 評(píng)論0 收藏0
  • 頁面性能優(yōu)化辦法有哪些?

    摘要:那我們?nèi)绾蝺?yōu)化頁面性能,提高頁面加載速度呢這是本文主要要探討的問題,然而性能優(yōu)化是個(gè)綜合性問題,沒有標(biāo)準(zhǔn)答案,想要面面俱到羅列出來,并非易事。三利用瀏覽器緩存對(duì)于應(yīng)用來說,緩存是提升頁面性能同時(shí)減少服務(wù)器壓力的利器。 引子 互聯(lián)網(wǎng)有一項(xiàng)著名的8秒原則。用戶在訪問Web網(wǎng)頁時(shí),如果時(shí)間超過8秒就會(huì)感到不耐煩,如果加載需要太長時(shí)間,他們就會(huì)放棄訪問。大部分用戶希望網(wǎng)頁能在2秒之內(nèi)就完成加載...

    raoyi 評(píng)論0 收藏0
  • 頁面性能優(yōu)化辦法有哪些?

    摘要:那我們?nèi)绾蝺?yōu)化頁面性能,提高頁面加載速度呢這是本文主要要探討的問題,然而性能優(yōu)化是個(gè)綜合性問題,沒有標(biāo)準(zhǔn)答案,想要面面俱到羅列出來,并非易事。三利用瀏覽器緩存對(duì)于應(yīng)用來說,緩存是提升頁面性能同時(shí)減少服務(wù)器壓力的利器。 引子 互聯(lián)網(wǎng)有一項(xiàng)著名的8秒原則。用戶在訪問Web網(wǎng)頁時(shí),如果時(shí)間超過8秒就會(huì)感到不耐煩,如果加載需要太長時(shí)間,他們就會(huì)放棄訪問。大部分用戶希望網(wǎng)頁能在2秒之內(nèi)就完成加載...

    rockswang 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<