摘要:意思告訴服務(wù)端當(dāng)該對象在的時間在之后,我的緩存不新鮮給我新鮮的。否則我的緩存就是新鮮的不需要再提供了。較小緩存未命中的請求會被導(dǎo)向較大父緩存。則是絕對的最大過期時間。
緩存介紹 緩存的優(yōu)點
減少冗余的數(shù)據(jù)傳輸 節(jié)省流量
緩解了網(wǎng)絡(luò)瓶頸的問題 不需高帶寬即可快速加載頁面
降低了對原始服務(wù)器的要求 服務(wù)器更快響應(yīng) 避免過載
降低了距離時延 服務(wù)器較遠 降低傳輸時間
什么情況下使用緩存冗余的數(shù)據(jù)傳輸(GET)
帶寬瓶頸
瞬間擁塞
。。。。。
緩存過程 一般緩存場景緩存命中:客戶端請求緩存 緩存將緩存的副本發(fā)送給客戶端
緩存未命中:客戶端請求緩存 緩存中沒有對應(yīng)的副本 請就被轉(zhuǎn)發(fā)給客戶端
緩存再驗證命中:客戶端請求緩存 緩存無法判斷該副本是否新鮮 發(fā)送驗證請求給服務(wù)端 服務(wù)器端返回仍是新鮮 緩存則將副本發(fā)送給客戶端
緩存處理步驟網(wǎng)絡(luò)中接收抵達的請求報文
緩存對報文進行解析 提出URL和各種首部
查詢本地是否有可用副本 沒有就保存一份在本地
查看副本是否足夠新鮮 新鮮檢測
緩存會用新的首部和緩存的主題來構(gòu)建報文
發(fā)送報文給客戶端
日志記錄事務(wù)
文檔過期Expires首部 HTTP/1.0 絕對的過期時間
Cache-Control:max-age首部 HTTP/1.1 定義文檔的最大使用期,最大的合法生存時間(單位:s)
文檔過期了 并不代表其就不新鮮了 下一步就是服務(wù)器再驗證 詢問文檔是否發(fā)生變化
If-Modified-Since首部
If-None-Match:tags首部
當(dāng)瀏覽器第一次從服務(wù)端獲取數(shù)據(jù)響應(yīng)為200的時候,緩存會獲取Last-Modified字段。
再驗證的時候,會在請求中加上If-Modified-Since字段,該字段的值就是Last-Modified字段的值。意思告訴服務(wù)端當(dāng)該對象在的Last-Modified時間在If-Modified-Since之后,我的緩存不新鮮給我新鮮的。 否則我的緩存就是新鮮的不需要再提供了。
服務(wù)端一般會有三中響應(yīng):
再驗證命中:對象未修改 304 Not Modified(成功的再驗證比緩存未命中要快,失敗的再驗證幾乎和未命中速度一樣)
再驗證未命中:對象修改了 200 OK
對象被刪除:404 Not Found 緩存也會刪除對應(yīng)副本
If-None-Match但是也有一些特殊情況
文檔周期行重寫(后臺進程寫入)實際包含數(shù)據(jù)一樣 內(nèi)容一樣 但是修改日期發(fā)生變化
文檔那個修改了 不過修改不重要 不需要緩存更新
有些服務(wù)器無法判斷其最后修改時間
有些服務(wù)器會在亞秒間隙發(fā)生變化 對于服務(wù)器來說 以一秒為單位的粒度修改日期就不夠了
這種情況 采用的方法就是打tag 加班本號
If-None-Mathc可以是多個,告訴服務(wù)器這些實體標(biāo)簽對應(yīng)的對象均有存在緩存副本
服務(wù)器可以通過HTTP定義的幾種方式制定文檔緩存多久 按照優(yōu)先級
Cache-Control:public
Cache-Control:no-store
Cache-Control:no-cache
Cache-Control:must-revalidate
Cache-Control:max-age
Expires:date
不添加過期時間 讓瀏覽器自己判斷
這里no-store緩存對響應(yīng)進行復(fù)制,緩存會轉(zhuǎn)發(fā)響應(yīng),刪除對象
no-cache實際上是可以存儲在本地緩存中的,只是在于原始服務(wù)器進行新鮮驗證之前 不能提供給客戶端使用
Cache-Control:max-age還有一種
Cache-Control:s-maxage=3600 僅針對的是共享緩存
max-age=0則是不使用緩存 每次進入都要刷新
must-revalidate告訴緩存 在沒有跟服務(wù)器進行新鮮驗證的情況下 不允許提供
一個允許緩存的報文信息
一份不可以緩存的報文信息
緩存命中率:有緩存提供的請求占所有請求的比例
字節(jié)命中率:緩存字節(jié)占總字節(jié)比例
對比響應(yīng)的Date字段 如果響應(yīng)的Date字段比當(dāng)前時間較早 則說明來自緩存
私有緩存:瀏覽器緩存 (瀏覽器輸入chrome://cache/查看本地緩存)
共有代理緩存:緩存代理服務(wù)器
實際情況中通常是層次化緩存。較小緩存未命中的請求會被導(dǎo)向較大父緩存。
靠近客戶端的地方使用較小廉價緩存,在更高層次中,則逐步采用更大,功能更強的緩存,來裝載多用戶共享的文檔
網(wǎng)狀緩存也叫內(nèi)容路由器:代理緩存之間會議更加復(fù)雜的方式對話,做出動態(tài)的緩存通信決定,決定于那個父緩存進行通話,或者決定徹底繞開緩存,直接連接原始服務(wù)器
其包含以下功能:
根據(jù)URL在父緩存或原始服務(wù)器回見進行動態(tài)選擇
根據(jù)URL動態(tài)選擇一個特定的父緩存
前往父緩存之前 在本地緩存中搜索一緩存的副本
允許其他緩存對其緩存的部分進行訪問 但不允許流浪訪問緩存
緩存的復(fù)雜關(guān)系允許不同的組織互為對等實體,緩存共享(兄弟緩存)。HTPP不支持兄弟緩存,因此還有一些協(xié)議(HTCP)快播P2P?
首部字段 | 值 | 描述 |
---|---|---|
Cache-Control | public | 響應(yīng)可以被緩存(默認) |
-- | private | 響應(yīng)可以被瀏覽器緩存 但是不允許中繼緩存(CDN)緩存 |
-- | no-store | 禁止瀏覽器和中繼緩存進行緩存 |
-- | no-cache | 瀏覽器可以緩存 但是未經(jīng)新鮮度檢查之前不能使用 |
-- | max-age | 一個以秒為單位數(shù)字,是一個相對時間。 Date+max-age則是絕對的最大過期時間。 |
Expires | date | HTTP/1.0標(biāo)準的 絕對過期時間 |
Date | date | 只存在于response中 報文響應(yīng)時候的時間 |
Last-Modified | date | 只存在于response中 文檔最后被修改的時間 |
If-Modified-Since | date | 只存在于request中 新鮮度度檢驗時候需要 查詢文檔是否在該時刻之后修改過 如果未修改過 更新緩存的文檔的Date,并且提供緩存副本 如果修改過 更新新的文檔,提供新的文檔 |
If-None-Match | tag | 只存在于request中 告訴服務(wù)端這些版本有對應(yīng)的緩存 |
Pragma | no-cache等 | HTTP/1.0時代的首部字段 功能相當(dāng)于Cache-Control |
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/61868.html
摘要:以下知識點是前輩師兄總結(jié)基礎(chǔ)語義化標(biāo)簽引進了一些新的標(biāo)簽,特別注意等,注意的標(biāo)題結(jié)構(gòu)理解瀏覽器解析的過程,理解的樹形結(jié)構(gòu),及相應(yīng)理解標(biāo)簽在各個瀏覽器上的默認樣式代理樣式,理解中的重置樣式表的概念理解等功能性標(biāo)簽理解標(biāo)簽,理解文件提交過程推薦 以下知識點是前輩師兄總結(jié) 1、HTML/HTML5基礎(chǔ): 1.0、語義化H5標(biāo)簽1.1、H5引進了一些新的標(biāo)簽,特別注意article...
摘要:以下知識點是前輩師兄總結(jié)基礎(chǔ)語義化標(biāo)簽引進了一些新的標(biāo)簽,特別注意等,注意的標(biāo)題結(jié)構(gòu)理解瀏覽器解析的過程,理解的樹形結(jié)構(gòu),及相應(yīng)理解標(biāo)簽在各個瀏覽器上的默認樣式代理樣式,理解中的重置樣式表的概念理解等功能性標(biāo)簽理解標(biāo)簽,理解文件提交過程推薦 以下知識點是前輩師兄總結(jié) 1、HTML/HTML5基礎(chǔ): 1.0、語義化H5標(biāo)簽1.1、H5引進了一些新的標(biāo)簽,特別注意article...
摘要:其中負載均衡那一節(jié),基本上是參考的權(quán)威指南負載均衡的內(nèi)容。開發(fā)指南讀了一半,就是看這本書理解了的事件循環(huán)。哈哈創(chuàng)京東一本騙錢的書。 歡迎大家前往騰訊云+社區(qū),獲取更多騰訊海量技術(shù)實踐干貨哦~ 本文由騰訊IVWEB團隊 發(fā)表于云+社區(qū)專欄作者:link 2014年一月以來,自己接觸web前端開發(fā)已經(jīng)兩年多了,記錄一下自己前端學(xué)習(xí)路上看過的,以及道聽途說的一些書,基本上按照由淺入深來介紹...
摘要:其中負載均衡那一節(jié),基本上是參考的權(quán)威指南負載均衡的內(nèi)容。開發(fā)指南讀了一半,就是看這本書理解了的事件循環(huán)。哈哈創(chuàng)京東一本騙錢的書。 歡迎大家前往騰訊云+社區(qū),獲取更多騰訊海量技術(shù)實踐干貨哦~ 本文由騰訊IVWEB團隊 發(fā)表于云+社區(qū)專欄作者:link 2014年一月以來,自己接觸web前端開發(fā)已經(jīng)兩年多了,記錄一下自己前端學(xué)習(xí)路上看過的,以及道聽途說的一些書,基本上按照由淺入深來介紹...
閱讀 3447·2023-04-26 01:45
閱讀 2222·2021-11-23 09:51
閱讀 3638·2021-10-18 13:29
閱讀 3428·2021-09-07 10:12
閱讀 698·2021-08-27 16:24
閱讀 1765·2019-08-30 15:44
閱讀 2192·2019-08-30 15:43
閱讀 2944·2019-08-30 13:11