静的オブジェクト(アイコンなど)は変更されません。 したがって、期限が切れない(妥当な期間)ように、不要なトラフィックを減らすように、システムを設定する必要があります。
これは、次のような影響を与えます。
ファイルの「有効期限」に関して、HTTP 標準で有効期限が指定されます ( 例: RFC 2616 "ハイパーテキスト転送プロトコル — HTTP 1.1")。 この標準では、ヘッダーを使用して、クライアントが古いと見なされるまでオブジェクトをキャッシュできるようにします。このようなオブジェクトは、元のサーバーに対してステータスチェックが行われず、指定された時間キャッシュされます。
この設定は、Dispatcher とは別のもので、Dispatcher に対しては機能しません。
Dispatcher の目的は、Adobe Experience Manager(AEM) の前でデータをキャッシュすることです。
動的ではなく、時間が経過しても変化しないファイルはすべてキャッシュ可能であり、またキャッシュする必要があります。Apache HTTPD サーバーの設定は、環境により、次のいずれかのようになります。
オブジェクトの有効期間を定義する際は、注意が必要です。指定した期間が経過するまではステータスのチェックがおこなわれないので、クライアントがキャッシュ内の古いコンテンツを提示する可能性があります*。*
作成者インスタンスの場合:
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ファイルを、期限が切れるまで最大 1 ヶ月間保存できます。 つまり、AEMまたは Web サーバーからリクエストする必要はありませんが、ブラウザーのキャッシュに残ることができます。
サイトの他のセクションは、いつでも変更される可能性があるので、1 つのオーサーインスタンス上にキャッシュしないでください。
パブリッシュインスタンスの場合:
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ファイルを最大 1 日間クライアントキャッシュに保存できます。 この例では、/content
および /etc/designs
の下にあるすべてについてグローバル設定を示していますが、より詳細に設定する必要があります。
サイトの更新頻度に応じて、HTMLページのキャッシュも検討できます。 妥当な期間は 1 時間です。
<Location /content>
ExpiresByType text/html "access plus 1 hour"
</Location>
静的オブジェクトの設定が完了したら、該当するオブジェクトが保持されているページを選択した状態で request.log
をスキャンして、静的オブジェクトに対する(不必要な)要求がおこなわれていないことを確認します。