首頁 > 運維 > Nginx > 主體

nginx expires控制頁面快取的方法

王林
發布: 2023-05-12 08:04:05
轉載
1680 人瀏覽過

語法:expires [time|epoch|max|pff]預設值:offexpires指令控制http應答中的「expires」和「cache-control」header頭部訊息,啟動控制頁面快取的作用time:可以使用正數或負數。 “expires”頭標的值將透過目前系統時間加上設定time值來設定。 time值也控制"cache-control"的值:負數表示no-cache正數或零表示max-age=time epoch:指定「expires」的值為1january,1970,00:00:01 gmtmax:指定「expires 」的值為31december2037 23:59:59gmt,"cache-control"的值為10年。 -1:指定「expires」的值為目前伺服器時間-1s,即永遠過期。 off:不修改「expires」和"cache-control"的值
expires使用了特定的時間,並且要求伺服器和客戶端的是中嚴格同步。
而cache-control是用max-age指令指定元件被緩存多久。
對於不支援http1.1的瀏覽器,還是需要expires來控制。所以最好能指定兩個響應頭。但http規範規定max-age指令將重寫expires頭。

如果不想讓代理程式或瀏覽器緩存,加上no-cache參數或private參數:
# expires 1d;
add_header cache-control no-cache;
add_header cache-control private ;
這樣瀏覽器f5刷新時,回傳的依然是200,而不是304.

記錄一個nginx控制快取的範例:
       expires 1d;
      add_ expires 1d;
      add_er-ache-trold cache;
       add_header cache-control private;
       if (!-e $request_filename) {
    #   add_header cache-control no-cache;
  #   add_header cache-control private;
當我將add_header寫在rewrite之後時,發現add_header竟然不起作用了。 。是因為寫進了if裡面..


apache的mod_expires模組使得在使用expires頭時能像max-age那樣以相對的方式設定日期,透過expiresdefault指令完成。例如:圖片等過期時間為請求開始的10年後

expiresdefault "access plus 10years"

它像回應中發送expires頭和cache-control max-age頭。

expires|etag控制頁面快取區別expires:像上面文章提到的:expires指令控制http應答中的「expires」和「cache-control」header頭部訊息,啟動控制頁面快取的作用time :可以使用正數或負數。 “expires”頭標的值將透過目前系統時間加上設定time值來設定。 time值也控制"cache-control"的值:負數表示no-cache正數或零表示max-age=time epoch:指定「expires」的值為1january,1970,00:00:01 gmtmax:指定「expires 」的值為31december203723:59:59gmt,"cache-control"的值為10年。 -1:指定「expires」的值為目前伺服器時間-1s,即永遠過期。 off:不修改「expires」和"cache-control"的值

expires使用了特定的時間,並且要求伺服器和客戶端的是中嚴格同步。
而cache-control是用max-age指令指定元件被緩存多久。
對於不支援http1.1的瀏覽器,還是需要expires來控制。所以最好能指定兩個響應頭。但http規範規定max-age指令將重寫expires頭。一般用於頁面變化不是很快的時候,如果快取過期了,瀏覽器在重用它之前會首先確認他是否有效,就是一個“條件get請求”,如果有效,返回304狀態碼。 expires透過last-modified響應頭來決定。如圖:
第一次造訪:
請求:
nginx expires控制页面缓存的方法

返回:
nginx expires控制页面缓存的方法

第二次存取:
請求:
nginx expires控制页面缓存的方法

返回:
nginx expires控制页面缓存的方法

這時回傳的狀態碼是304,而在請求中比第一次多了if-modified -since頭,和原始伺服器中的last-modified製作比較,所以實現瀏覽器快取並判斷是否過期。
簡單的說,last-modified 與if-modified-since 都是用來記錄頁面最後修改時間的http 頭訊息,只是last-modified 是由伺服器傳送到客戶端的http 頭,而if-modified-since則是由客戶端向伺服器發送的頭,可以看到,再次要求本地存在的cache 頁面時,客戶端會透過if-modified-since頭將先前伺服器端發過來的last-modified最後修改時間戳發送回去,這是為了讓伺服器端進行驗證,透過這個時間戳判斷客戶端的頁面是否是最新的,如果不是最新的,則傳回新的內容,如果是最新的,則傳回304告訴客戶端其本機cache的頁面是最新的,於是客戶端就可以直接從本地加載頁面了,這樣在網路上傳輸的資料就會大大減少,同時也減輕了伺服器的負擔。

如果不想讓代理程式或瀏覽器緩存,加上no-cache參數或private參數:
# expires 1d;
add_header cache-control no-cache;
add_header cache-control private ;
nginx expires控制页面缓存的方法



etag:實體標籤,是用來確認網頁伺服器和瀏覽器快取有效性的一種機制。原始伺服器使用etag回應頭來指定元件的etag瀏覽器透過if-none-match頭將etag傳回原始伺服器。如果匹配,返回304
如圖:
第一次訪問:
請求:
nginx expires控制页面缓存的方法

返回:
nginx expires控制页面缓存的方法


nginx expires控制页面缓存的方法


nginx expires控制页面缓存的方法





#########第二次請求:############返回:############仍傳回的狀態碼是304,而在請求中比第一次多了if -none-match頭。所以實現瀏覽器快取。如果這個值對不上,則快取過期。 ###etags和if-none-match是一種常用的判斷資源是否改變的方法。類似last-modified和http-if-modified-since。但有所不同的是last-modified和http-if-modified-since只判斷資源的最後修改時間,而etags和if-none-match可以是資源任何的任何屬性。 ###etags和if-none-match的工作原理是在httpresponse中加入etags資訊。當客戶端再次請求該資源時,將在httprequest中加入if-none-match資訊(etags的值)。如果伺服器驗證資源的etags沒有改變(該資源沒有改變),將傳回一個304狀態;否則,伺服器將傳回200狀態,並傳回該資源和新的etags。 ###iis上的etag格式需要修改。 ######

以上是nginx expires控制頁面快取的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!