頁面緩存是安裝在Web服務器之前的緩存服務器,用于卸載對服務器上的靜態(tài)和動態(tài)對象的請求。該系統(tǒng)或服務器器的常見名稱還有反向代理緩存、反向代理服務器和反向代理。經過慎重考慮,我們采用了頁面緩存這個術語,因為代理程序還會負責負載平衡或SSL加速,而我們只想專注于緩存服務器對可擴展性的影響。被實現(xiàn)的代理緩存如圖64所示。頁面緩存會處理部分或所有請求,直到它存儲的頁面或數據過期了,或服務器收到的請求了它沒有存儲的數據。請求失敗叫做緩存未命中,原因可能是緩存滿了,沒有空間為最新的請求存儲數據,也可能是緩存未滿,但請求頻率較低或最近重啟過。緩存未命中會被傳遞給Web服務器,Web服務器用該請求回答并填充緩存,從而替換緩存中最近很少使用的記錄,或者在空白處寫入數據。
在這個原則中,有三個關鍵點。
第一點,應該在Web服務器前實現(xiàn)頁面緩存(反向代理程序),這樣你就會得到很大的可擴展性。生成動態(tài)內容的Web服務器的工作量會大大減少,因為計算過的結果(或響應)在合適的時間被恰當地緩存了。提供靜態(tài)內容的Web服務器不需要查詢那些內容,可以少用一些緩存。我們同意,靜態(tài)內容的頁面緩存的好處沒有動態(tài)內容的頁面緩存那么大。
第二點,需要利用正確的HTTP頭,確保對內容和查詢結果進行最大化的緩存(當然還要確保業(yè)務正確)。
第三點,盡可能加入RFC2616中的另一個HTTP頭,從而最大化內容的可緩存性。這個新的頭是ETag,也就是實體標簽(entity tag),目的是配合If-None-Match有條件地從服務器獲得請求。ETag是由服務器在瀏覽器第一次請求一個對象時賦予該對象的唯一標識符。如果服務器端的資源改變了,那么服務器會為它分配一個新的Erag。假設能被瀏覽器(客戶端)正確地支持,對象和它的ETag標簽就會被瀏覽器緩存,之后瀏覽器向Web服務器發(fā)送的工f-None-Match請求都會包含該標簽。如果標簽匹配,服務器會用狀態(tài)HTIP304 Not Modified進行響應。如果該標簽與服務器上的不一致,服務器會發(fā)送更新過的對象以及與之相關的Etag-ETag是可選的,但如果要確保在任何特定的網站設計頁面或對象的整個網絡傳輸中,頁面緩存和代理緩存具有更大的可緩存性,強烈推薦使用Brag。
本文地址:http://www.youmaike.com//article/3475.html