靜態物件(例如圖示)不會變更。 因此,應將系統配置為使它們不會過期(在合理的時間段內),從而減少不必要的流量。
其影響如下:
HTTP標準會針對檔案的「過期」指定過期時間(例如,請參閱的第14.21章 RFC 2616 "超文本傳輸協定 — HTTP 1.1")。 此標準使用標頭,允許客戶端快取對象,直到它們被視為過時;這樣的對象被快取指定的時間量,而不對源伺服器進行任何狀態檢查。
此設定與Dispatcher完全分開(且不適用)。
Dispatcher的用途是快取AEM前面的資料。
可以且應快取所有非動態且不會隨時間變更的檔案。 Apache HTTPD伺服器的配置可能如下所示(取決於環境):
在定義將對象視為最新的時段時,必須小心。 因為 在指定的時段到期之前,不進行檢查,用戶端最後可能會從快取中顯示舊內容。
對於Author例項:
LoadModule expires_module modules/mod_expires.so
<Location /libs>
ExpiresByType text/css "access plus 1 month"
ExpiresByType text/javascript "access plus 1 month"
ExpiresByType image/png "access plus 1 month"
ExpiresByType image/gif "access plus 1 month"
</Location>
這可讓中繼快取(例如瀏覽器快取)最多儲存一個月的CSS、Javascript、PNG和GIF檔案,直到它們過期為止。 這表示不需要向AEM或Web伺服器要求這些檔案,但可保留在瀏覽器快取中。
網站的其他區段不應在製作例項上快取,因為這些區段隨時可能變更。
對於發佈例項:
LoadModule expires_module modules/mod_expires.so
<Location /content>
ExpiresByType text/css "access plus 1 day"
ExpiresByType text/javascript "access plus 1 day"
ExpiresByType image/png "access plus 1 day"
ExpiresByType image/gif "access plus 1 day"
</Location>
<Location /etc/designs>
ExpiresByType text/css "access plus 1 day"
ExpiresByType text/javascript "access plus 1 day"
ExpiresByType image/png "access plus 1 day"
ExpiresByType image/gif "access plus 1 day"
</Location>
這可讓中間快取(例如瀏覽器快取)在用戶端快取中儲存最多一天的CSS、Javascript、PNG和GIF檔案。 雖然此範例說明下方所有項目的全域設定 /content
和 /etc/designs
,您應讓其更精細。
您也可以考慮快取HTML頁面,視網站更新的頻率而定。 合理的時段為1小時:
<Location /content>
ExpiresByType text/html "access plus 1 hour"
</Location>
配置靜態對象後,掃描 request.log
,以確認沒有對靜態物件提出(不必要的)要求。