爲推動Web技術的發展,Brilliant Open Web 團隊特推出每個月一期的《移動Web加速技術月報》,該月報將整理較流行的移動Web加速技術,並跟進各項技術的進展和發展方向,以期幫助開發者瞭解或選用相關的技術,把握技術發展趨勢。歡迎關注【OpenWeb開發者】公衆號並回復「加羣」,一塊兒探討相關技術。web
做者 | Brilliant Open Web 團隊breezet、chengang、shdong 編輯 | 尾尾chrome
在上一期的月報中,咱們爲你們介紹了Web頁面中如何使用預取和預渲染來進行頁面加速,同時也指出了目前瀏覽器提供的預取和預渲染方法所存在的問題以及改進優化的思路。瀏覽器
本期,咱們將再次聚焦到一期討論的瀏覽器緩存、頁面雲端緩存等技術上,詳細展開討論各類頁面緩存技術能達到的效果以及所存在的一些問題。緩存
近幾年,不管是內容分發平臺仍是瀏覽器廠商都會經過雲端的頁面CDN Cache服務,爲用戶訪問Web頁面提供更快的頁面訪問。bash
經過更優質的CDN Cache,內容分發平臺或瀏覽器廠商經過中間代理的方式,讓用戶享受了更優質的頁面速度瀏覽體驗。因爲各公司提供的頁面緩存服務在對緩存的處理策略上不盡相同,也致使站點在提供Web服務時,不清楚應該如何配置才能被正確緩存而且對本身業務無其餘負面影響。服務器
本章節會詳細講述其中存在的問題,綜合百度在此方面的處理方案給出建議的通用標準實現。網絡
內容分發平臺或瀏覽器對Web頁面進行服務端的緩存,主要的目的是由於不少的站點服務自己並無提供較好的網絡環境和服務快速響應,經過將此類站點的頁面緩存在CDN Cache等網絡中(頁面代理緩存),能夠是用戶訪問此類站點時享受到極快的頁面加載。dom
可是,目前雲端緩存的規範是不明確,具體表現爲業界已經默認的規範不屬於任何組織(如x-forward-for),部分規範是瀏覽器提供商(chrome,Firefox)等提出的,並未徹底推動到標準中(如標識預加載的x-moz),從而致使頁面開發者在本身的頁面可能被緩存的狀況下,沒法正確的保障本身被緩存頁面的用戶體驗以及功能。異步
本文將從如下幾個方面在總結內容分發平臺或瀏覽器在代理緩存服務策略上的問題和解決方案:ide
本小節主要講述頁面站點在被瀏覽器或內容分發平臺的代理服務緩存時所面臨的問題,並給出對開發者更友好的緩存服務解決方案建議。
下圖是一個用戶訪問站點時的請求所通過的緩存相關的路徑。
瀏覽器部分雲加速服務,對頁面的修改以及緩存對開發者過於透明不可控,包括可是不限於:
代理緩存服務自己會在頁面訪問時抓取對應的頁面,所以可遵循如下緩存策略:
Cache-Control
來控制;Cache-Control
頭來控制緩存超時,用stale-while-revalidate
頭來控制平滑更新;百度搜索結果頁中的一個網站開發者,本身站點的/home/news/data
路徑下的全部頁面都是高時效性的頁面,不但願被任何加速服務緩存。爲了達到這個目的,站長應該在本身站點的robots.txt
文件中加入以下內容:
Cache:*
HttpsCacheDisallow:/home/news/data/
HttpCacheDisallow:/home/news/data/
# 對於全部的Cache來講,https和http的在/home/news/data/路徑下的全部內容不容許被緩存
# 若是但願各層加速能平滑更新,那麼能夠在Cache-Control頭裏面寫入以下內容:max-age=864000, stale-while-revalidate=1728000
# 代表:在86400s內本地緩存有效。在172800s內返回舊緩存的同時,異步發起更新。當時間超過172800s時,緩存失效,從新抓取。
複製代碼
全部遵循了緩存規範的服務解析站點的robots.txt文件後,不緩存/home/news/data
路徑下的全部內容。知足了開發者的需求。
固然,做爲站長,不能濫用此規範,由於不緩存的頁面每每意味着更慢的加載速度。
在這種場景下,處在HttpsCacheDisallow或者HttpCacheDisallow所配置的Path中的頁面所返回的Cache-Control等header將會僅僅被用來控制瀏覽器端的緩存。
相應的,對於瀏覽器自帶的雲加速服務器來講,方便在瀏覽器上作熱門站點的robots.txt文件,來判斷那些頁面能夠直接不經過本身的雲加速服務,而是直接訪問源站。
代理緩存服務進行頁面緩存時,也會給站長帶來數據統計上的困擾。本小節試圖從數據統計的方面,提供緩存服務在統計上的一些解決方案。
x-forward-for
頭來指名真實的用戶IP信息<meta x-forwad-for='true' sendTo='domain/path'>
本月報將收錄移動Web加速技術的主要進展,歡迎讀者一塊兒完善,投稿郵箱:openweb@baidu.com。
Mip:
AMP: 一、 amp-story 默認靜音,添加漸變效果,修復部分兼容性問題,提高組件使用體驗 二、 AdSense / Doubleclick 快速取回 unlayoutCallback 實驗 三、AMP 元素增長API,實現元素的調度時間傳遞給元素自己 四、 amp-analytics 增長新的分析服務商:Alexa Internet,增長參數this.isInabox_,支持基本批處理功能
百度在W3C 2017 TPAC會議上針對頁面雲端緩存策略的議題與全球各大互聯網公司有過深刻的交流和討論,也收到了你們的積極響應和回覆。
雲端緩存策略是一項重大的技術創新,但技術野蠻生長的同時也對開發者形成了巨大的困擾,隨着你們對此項技術的普遍深刻應用,雲端緩存策略必然須要統一的標準和規範,開發者經過統一的規範和標準,來配置本身的頁面的雲端緩存策略,來提供更可靠的體驗和功能。
歡迎各位讀者補充各項移動Web加速技術及其最新進展,能夠發送郵件到 openweb@baidu.com,也能夠關注【OpenWeb開發者】公衆號並回復「加羣」,一塊兒來探討相關技術,與咱們攜手推動Web技術的發展!