久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

你值得了解的HTTP緩存機制(代碼詳解)

之前的文章《深入解析vue中路由切換白屏的問題(附代碼)》中,給大家了解了vue中路由切換白屏的問題。下面本篇文章給大家了解HTTP緩存機制詳解,有一定的參考價值,有需要的朋友可以參考一下,希望對你們有所助。

你值得了解的HTTP緩存機制(代碼詳解)

Web緩存大致可以分為:數據庫緩存、服務器端緩存(代理服務器緩存、CDN緩存)、瀏覽器緩存。

瀏覽器緩存也包含很多內容:HTTP緩存、indexDB、cookielocalstorage等等。 這里要說的是http緩存。

使用緩存的好處

  • 減少了冗余的數據傳輸

  • 緩解了網絡瓶頸的問題

  • 降低了對原始服務器的要求

  • 降低了距離時延

術語

緩存命中率:從緩存中得到數據的請求數與所有請求數的比率。理想狀態是越高越好。

過期內容:超過設置的有效時間,被標記為“陳舊”的內容。通常過期內容不能用于回復客戶端的請求,必須重新向源服務器請求新的內容或者驗證緩存的內容是否仍然準備。

驗證:驗證緩存中的過期內容是否仍然有效,驗證通過的話刷新過期時間。

失效:失效就是把內容從緩存中移除。當內容發生改變時就必須移除失效的內容。

機制

你值得了解的HTTP緩存機制(代碼詳解)

策略

1)緩存存儲策略

緩存存儲策略決定了客戶端是否應該存儲httpresponse。與緩存存儲有關的http header主要為response header中的Cache-Control。該header有下面幾個對應的值:Public、Private、no-cache、max-age、no-store。除了no-store,其它幾種都會表明response應該被客戶端緩存。

指令 說明
Public 所有內容都將被緩存(客戶端和代理服務器都可緩存)
Private 內容只緩存到私有緩存中(僅客戶端可以緩存,代理服務器不可緩存)
max-age = xxx (xxx is numeric) 緩存的內容將在 xxx 秒后失效,失效前可以直接使用本地緩存,失效后必須向服務器確認資源是否已經改變。
no-store 完全不在客戶端緩存
no-cache 可以認為等同于 max-age=0 的情況,即將 response 緩存在客戶端,但是之后每次都向服務器確認資源是否已經改變

通過Cache-Control:Public設置我們可以將HTTP響應數據存儲到本地,但此時并不意味著后續瀏覽器會直接從緩存中讀取數據并使用, 因為它無法確定本地緩存的數據是否可用(可能已經失效),需通過緩存過期策略來判斷

2)緩存過期策略

緩存過期策略決定了客戶端存儲在本地的緩存數據是否已過期,如未過期則可以直接使用本地存儲的數據,否則就需要發請求到服務端嘗試重新獲取數據。 與緩存過期策略有關的http header 為Expires。

Expires表示緩存數據有效的絕對時間,告訴客戶端到了這個時間點后本地緩存就失效了,在這個時間內客戶端可以不請求服務器而直接從本地緩存中使用已存儲的結果。

需要注意的是:no-cache和max-age=xxx的優先級高于Expires,當它們同時存在的時候,后者會被覆蓋掉。其次, 緩存數據過期只是告訴客戶端不能再直接從本地讀取緩存了,而是需要再發一次請求到服務器去確認。具體什么情況下本地存儲的數據還可以繼續使用就與緩存對比策略有關了。

3)緩存對比策略

將緩存在客戶端的數據標識發往服務端,服務端通過標識來判斷客戶端緩存數據是否仍有效,進而決定是否要重發數據??蛻舳藱z測到數據過期或瀏覽器刷新后,會重新發起一個 http 請求到服務器,服務器此時并不急于返回數據,而是看請求頭有沒有帶標識(If-Modified-Since、If-None-Match)過來,如果判斷標識仍然有效,則返回304告訴客戶端取本地緩存數據來用即可(這里要注意的是你必須要在首次響應時輸出相應的頭信息(Last-Modified、ETags)到客戶端)。 本地緩存數據即使被認為過期,并不等于數據從此就沒用了。

緩存過期取值

存儲策略里面no-cache等同于max-age=0,假如服務端返回的響應中沒有指明max-age、no-cacheExpires時,客戶端是否會緩存 http response呢 ?通過FiddlerCharles等抓包工具可以發現,客戶端一樣會進行緩存

其取值值為響應頭中的DateLast-Modified之間的差值的10%作為緩存有效時間

FiddlerCaching面板中可以看到

HTTP/1.1 Cache-Control Header is present: private HTTP Last-Modified Header is present: Tue, 08 Nov 2016 06:59:00 GMT No explicit HTTP Cache Lifetime information was provided. Heuristic expiration policies suggest defaulting to: 10% of the delta between Last-Modified and Date. That's '05:15:02' so this response will heuristically expire 2016/11/11 0:46:01.

用一副圖來表示

你值得了解的HTTP緩存機制(代碼詳解)

緩存的控制

1)強制緩存

可以通過Expires,Cache-Control來設定,Expires指緩存過期的時間,超過了這個時間點就代表資源過期。有一個問題是由于使用具體時間,如果時間表示出錯或者沒有轉換到正確的時區都可能造成緩存生命周期出錯。 并且ExpiresHTTP/1.0的標準,現在更傾向于用HTTP/1.1中定義的Cache-Control。兩個同時存在時也是Cache-Control的優先級更高。

2)協商緩存

緩存的資源到期了,并不意味著資源內容發生了改變,如果和服務器上的資源沒有差異,實際上沒有必要再次請求??蛻舳撕头掌鞫送ㄟ^某種驗證機制驗證當前請求資源是否可以使用緩存。 瀏覽器第一次請求數據之后會將數據和響應頭部的緩存標識存儲起來。再次請求時會帶上存儲的頭部字段,服務器端驗證是否可用。如果返回304 Not Modified,代表資源沒有發生改變可以使用緩存的數據,獲取新的過期時間。反之返回200就相當于重新請求了一遍資源并替換舊資源。

Last-modified/If-Modified-Since

Last-modified: 服務器端資源的最后修改時間,響應頭部會帶上這個標識。第一次請求之后,瀏覽器記錄這個時間,再次請求時,請求頭部帶上If-Modified-Since即為之前記錄下的時間。服務器端收到帶If-Modified-Since的請求后會去和資源的最后修改時間對比。若修改過就返回最新資源,狀態碼200,若沒有修改過則返回304。

你值得了解的HTTP緩存機制(代碼詳解)

Etag/If-None-Match

由服務器端上生成的一段hash字符串,第一次請求時響應頭帶上ETag: abcd,之后的請求中帶上If-None-Match: abcd,服務器檢查ETag,返回304200。

關于 last-modified 和 Etag 區別

  • 某些服務器不能精確得到資源的最后修改時間,這樣就無法通過最后修改時間判斷資源是否更新。

  • Last-modified只能精確到秒。

  • 一些資源的最后修改時間改變了,但是內容沒改變,使用Last-modified看不出內容沒有改變。

  • Etag的精度比Last-modified高,屬于強驗證,要求資源字節級別的一致,優先級高。如果服務器端有提供ETag的話,必須先對ETag進行Conditional Request。

注意:實際使用ETag/Last-modified要注意保持一致性,做負載均衡和反向代理的話可能會出現不一致的情況。計算ETag也是需要占用資源的,如果修改不是過于頻繁,看自己的需求用Cache-Control是否可以滿足。

實際應用

首先要明確哪些內容適合被緩存哪些不適合。

考慮緩存的內容:css樣式文件,js文件,logo、圖標,html文件,可以下載的內容一些不應該被緩存的內容:業務敏感的GET請求

可緩存的內容又分為幾種不同的情況:

不經常改變的文件:給max-age設置一個較大的值,一般設置max-age=31536000比如引入的一些第三方文件、打包出來的帶有hash后綴cssjs文件。一般來說文件內容改變了,會更新版本號、hash值,相當于請求另一個文件。 標準中規定max-age的值最大不超過一年,所以設成max-age=31536000。至于過期內容,緩存區會將一段時間沒有使用的文件刪除掉。

[完]

推薦學習:Html5視頻教程

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
国产精品久久久久久久久久齐齐 | 三级亚洲高清视频| 136国产福利精品导航网址| 香蕉久久精品| 日韩影院在线观看| 欧美在线91| 国产suv精品一区| 久久精品高清| 蜜臀av一区二区在线免费观看| 日本亚洲最大的色成网站www | 国产精品最新| 亚洲国产福利| 欧美精选一区二区三区| 亚洲精品护士| 国产一区二区三区不卡视频网站 | 好吊日精品视频| 涩涩涩久久久成人精品| 国产精品网站在线看| 国产中文欧美日韩在线| 蜜桃tv一区二区三区| 蜜桃视频在线观看一区二区| 国产美女撒尿一区二区| 国产伦精品一区二区三区视频| 激情国产在线| 亚洲一区日本| 日韩av不卡一区二区| 高清在线一区| 亚洲免费成人| 国产精品观看| 欧美高清一区| 国产乱子精品一区二区在线观看| 欧美一区久久久| 亚州av乱码久久精品蜜桃| 日本麻豆一区二区三区视频| 日本蜜桃在线观看视频| 视频在线在亚洲| 国产专区精品| 水野朝阳av一区二区三区| 久久午夜影院| 视频一区欧美精品| 福利片在线一区二区| 午夜精品免费| 免费观看亚洲天堂| 国产精品外国| 三上亚洲一区二区| 免费人成网站在线观看欧美高清| 六月丁香综合在线视频| 久久三级视频| 老色鬼久久亚洲一区二区| 丁香婷婷久久| 亚洲欧洲av| 999视频精品| 国产精品久久久久77777丨| 91久久中文| 在线亚洲人成| 欧美精品国产一区| 欧美精品自拍| 国产精品精品| 国产欧美日韩亚洲一区二区三区| 亚洲视频综合| 久久一区视频| 色8久久久久| 久久中文字幕av一区二区不卡| 欧美私人啪啪vps| 99综合视频| 肉色欧美久久久久久久免费看 | 美女国产一区二区三区| 中文字幕日本一区| 亚洲午夜黄色| 黑森林国产精品av| 久久精品五月| 国产亚洲欧美日韩精品一区二区三区| 国产亚洲在线观看| 999国产精品| 欧美激情综合| 日本色综合中文字幕| 亚洲欧美视频| 伊人久久成人| 亚洲性色视频| 久久精品动漫| 成人va天堂| 日韩一区亚洲二区| 国产不卡人人| 国产精品蜜芽在线观看| 久久久久久色| 亚洲精品一级| 蜜臀av国产精品久久久久| 蜜桃视频第一区免费观看| 在线综合欧美| 极品日韩av| 视频小说一区二区| 日韩精品久久久久久久电影99爱| 日韩不卡一区| 正在播放日韩精品| 日本激情一区| 97视频热人人精品免费| 91视频一区| 日韩欧美在线中字| 日韩一区亚洲二区| 日韩欧美自拍| 亚洲综合电影| 国产一区二区三区黄网站| 精品精品99| 日韩精品高清不卡| 爽好多水快深点欧美视频| 中文无码久久精品| 一本色道久久精品| 波多野结衣一区| 亚洲v在线看| 中文字幕系列一区| 国产成人精品亚洲线观看| 国产精品网在线观看| 欧美日本不卡高清| 国产精品最新| 麻豆视频久久| 91精品国产自产在线丝袜啪| 国产乱人伦丫前精品视频| 欧美日本久久| 国产精品一二| 国产亚洲一区| 国产精品一站二站| 亚欧成人精品| 国产亚洲一区二区三区啪| 欧美精品国产白浆久久久久| 欧美亚洲人成在线| 欧美综合社区国产| 国产极品模特精品一二| 日本午夜精品久久久久| 麻豆中文一区二区| 欧美xxxx中国| 精品免费av在线| 亚洲成av在线| 亚洲91精品| 99久久九九| 日韩午夜黄色| 亚洲欧美日韩国产一区| 最近国产精品视频| 日韩av一级片| 国产精品任我爽爆在线播放| 免费看久久久| 久久精品资源| 久久香蕉国产| 先锋亚洲精品| 日韩激情中文字幕| 国产精品永久| 国产一区二区三区黄网站| 成人台湾亚洲精品一区二区| 免费av一区| 久久www成人_看片免费不卡| 亚洲一区二区网站| 日本精品国产| 精品一区二区三区中文字幕视频 | 亚洲精品在线观看91| 免费久久99精品国产| 青青草国产成人99久久| 国产麻豆精品| 福利一区二区三区视频在线观看| 人人精品亚洲| 石原莉奈一区二区三区在线观看| 日本午夜免费一区二区 | 一区免费在线| 欧美日韩亚洲国产精品| 久久天堂影院| 亚洲一区导航| 久久字幕精品一区| av亚洲免费| 日韩av一区二区在线影视| 国产aⅴ精品一区二区四区| 黑丝一区二区| 日本aⅴ亚洲精品中文乱码| 欧美激情视频一区二区三区免费| 成人污污视频| 欧美福利一区| 欧美日韩中出| 国产欧洲在线| 69精品国产久热在线观看| 色综合五月天| 一区二区三区午夜视频| 精品国产一区二| 午夜久久影院| 欧美一区网站| 亚洲激情国产| 国产精品大片| 欧美国产91| 欧美国产不卡| 亚洲成人一区| 国产欧美日韩亚洲一区二区三区| 色偷偷偷在线视频播放| 亚洲五月综合| 国产不卡av一区二区| 日韩精品一区二区三区中文字幕| 日韩电影免费网站| 日韩精品一区二区三区中文在线| 日韩免费一区| 日韩不卡在线观看日韩不卡视频| 日本综合字幕| 成人国产精品一区二区网站| 最新国产精品视频| 深夜福利视频一区二区| 日韩在线视频一区二区三区|