mirror of
https://github.com/apache/httpd.git
synced 2025-07-07 09:41:11 +03:00
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1677177 13f79535-47bb-0310-9956-ffa450edef68
1215 lines
55 KiB
Plaintext
1215 lines
55 KiB
Plaintext
<?xml version="1.0"?>
|
|
<!DOCTYPE modulesynopsis SYSTEM "../style/modulesynopsis.dtd">
|
|
<?xml-stylesheet type="text/xsl" href="../style/manual.fr.xsl"?>
|
|
<!-- English Revision: 1674195 -->
|
|
<!-- French translation : Lucien GENTIS -->
|
|
<!-- Reviewed by : Vincent Deffontaines -->
|
|
|
|
<!--
|
|
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
contributor license agreements. See the NOTICE file distributed with
|
|
this work for additional information regarding copyright ownership.
|
|
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
(the "License"); you may not use this file except in compliance with
|
|
the License. You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
-->
|
|
|
|
<modulesynopsis metafile="mod_cache.xml.meta">
|
|
|
|
<name>mod_cache</name>
|
|
<description>Filtre de mise en cache HTTP conforme à la RFC 2616</description>
|
|
<status>Extension</status>
|
|
<sourcefile>mod_cache.c</sourcefile>
|
|
<identifier>cache_module</identifier>
|
|
|
|
<summary>
|
|
<note type="warning">Ce module doit être utilisé avec précautions
|
|
car lorsque la directive <directive
|
|
module="mod_cache">CacheQuickHandler</directive> est définie à sa
|
|
valeur par défaut <strong>on</strong>, les directives <directive
|
|
module="mod_access_compat">Allow</directive> and <directive
|
|
module="mod_access_compat">Deny</directive> sont court-circuitées. Vous
|
|
ne devez donc pas activer la gestion rapide de la mise en cache pour
|
|
un contenu auquel vous souhaitez limiter l'accès en fonction du nom
|
|
d'hôte du client, de l'adresse IP ou d'une variable
|
|
d'environnement.</note>
|
|
|
|
<p><module>mod_cache</module> implémente un <strong>filtre de mise
|
|
en cache de contenu HTTP</strong> conforme à la <a
|
|
href="http://www.ietf.org/rfc/rfc2616.txt">RFC 2616</a>, avec
|
|
support de la mise en cache des réponses dont le contenu a été
|
|
négocié et comportant l'en-tête Vary.</p>
|
|
|
|
<p>La mise en cache conforme à la RFC 2616 fournit un mécanisme
|
|
permettant de vérifier si un contenu expiré ou dépassé est encore à
|
|
jour, et peut apporter un gain de performances significatif si le
|
|
serveur original supporte les <strong>requêtes
|
|
conditionnelles</strong> en prenant en compte l'en-tête de requête
|
|
HTTP <a
|
|
href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.26">If-None-Match</a>.
|
|
Le contenu n'est ainsi régénéré que lorsqu'il a été modifié, et non
|
|
lorsqu'il a expiré.</p>
|
|
|
|
<p>En tant que filtre, <module>mod_cache</module> peut être placé
|
|
en face d'un contenu issu de tout gestionnaire, y compris
|
|
<strong>des fichiers à accès séquentiel</strong> (servis depuis un
|
|
disque lent mis en
|
|
cache sur un gros disque), la sortie d'un <strong>script
|
|
CGI</strong> ou d'un <strong>générateur de contenu
|
|
dynamique</strong>, ou du contenu <strong>mandaté depuis un autre
|
|
serveur</strong>.</p>
|
|
|
|
<p>Dans la configuration par défaut, <module>mod_cache</module>
|
|
place le filtre de mise en cache aussi loin que possible dans la
|
|
pile de filtres, utilisant le <strong>gestionnaire rapide</strong>
|
|
pour court-circuiter tout traitement par requête lors de l'envoi du
|
|
contenu au client. Dans ce mode opératoire,
|
|
<module>mod_cache</module> peut être considéré comme un serveur
|
|
mandataire avec cache fixé en tête du serveur web, alors qu'il
|
|
s'exécute dans ce même serveur web.</p>
|
|
|
|
<p>Lorsque le gestionnaire rapide est désactivé via la directive
|
|
<directive module="mod_cache">CacheQuickHandler</directive>, il
|
|
devient possible d'insérer le filtre <strong>CACHE</strong> à un
|
|
point de la pile de filtres choisi par l'administrateur. Ceci permet
|
|
de mettre en cache un contenu avant que celui-ci ne soit
|
|
personnalisé par le filtre <module>mod_include</module>, ou
|
|
éventuellement compressé par le filtre <module>mod_deflate</module>.</p>
|
|
|
|
<p>Dans le mode de fonctionnement normal, <module>mod_cache</module>
|
|
peut être contrôlé par les en-têtes <a
|
|
href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9">Cache-Control</a>
|
|
et <a
|
|
href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.32">Pragma</a>
|
|
envoyés par un client dans une requête, ou par un serveur dans une
|
|
réponse. Dans des circonstances exceptionnelles,
|
|
<module>mod_cache</module> peut cependant être configuré pour
|
|
outrepasser ces en-têtes et forcer un comportement spécifique au
|
|
site, bien qu'un tel comportement sera limité à ce cache seulement,
|
|
et n'affectera pas les opérations des autres caches qui peuvent
|
|
s'insérer entre le client et le serveur, et ce type de configuration
|
|
ne doit donc être utiliser qu'en cas de nécessité absolue.</p>
|
|
|
|
<p>La RFC 2616 permet au cache de renvoyer des données périmées
|
|
pendant que l'entrée périmée correspondante est mise à jour depuis
|
|
le serveur original, et <module>mod_cache</module> supporte cette
|
|
fonctionnalité lorsque la directive <directive
|
|
module="mod_cache">CacheLock</directive> est configurée en
|
|
conséquence. De telles réponses comportent un en-tête HTTP <a
|
|
href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.46">Warning</a>
|
|
contenant un code de réponse 110. La RFC 2616 permet aussi au cache
|
|
de renvoyer des données périmées lorsque la tentative de mise à jour
|
|
des données périmées renvoie une erreur 500 ou supérieure, et cette
|
|
fonctionnalité est supportée par défaut par
|
|
<module>mod_cache</module>. De telles réponses comportent un en-tête HTTP <a
|
|
href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.46">Warning</a>
|
|
contenant un code de réponse 111.</p>
|
|
|
|
<p><module>mod_cache</module> requiert les services d'un ou
|
|
plusieurs modules de gestion de stockage. La distribution Apache de base
|
|
inclut les modules de gestion de stockage suivants :</p>
|
|
<dl>
|
|
<dt><module>mod_cache_disk</module></dt>
|
|
|
|
<dd>implémente un gestionnaire de stockage sur disque. Les en-têtes
|
|
et corps sont stockés séparément sur le disque dans une structure de
|
|
répertoires basée sur le condensé md5 de l'URL mise en cache.
|
|
Plusieurs réponses à contenu négocié peuvent être stockées en même
|
|
temps, mais la mise en cache de contenus partiels n'est pas
|
|
supportée par ce module. L'utilitaire
|
|
<program>htcacheclean</program> permet de lister et de supprimer les
|
|
URLs mises en cache, et de maintenir le cache en deçà de
|
|
certaines limites de taille et de nombre d'inodes.</dd>
|
|
<dt><module>mod_cache_socache</module></dt>
|
|
<dd>Implémente un gestionnaire de stockage basé sur un cache d'objets
|
|
partagés. Les en-têtes et corps sont stockés ensemble sous une seule
|
|
clé basée sur l'URL de la réponse mise en cache. Des réponses à
|
|
contenus multiples négociés peuvent être stockées simultanément, mais
|
|
ce module ne supporte pas la mise en cache de contenus partiels.</dd>
|
|
</dl>
|
|
|
|
<p>Pour de plus amples détails, une description, et des exemples,
|
|
reportez-vous au <a href="../caching.html">Guide de la mise en
|
|
cache</a>.</p>
|
|
</summary>
|
|
<seealso><a href="../caching.html">Guide de la mise en
|
|
cache</a></seealso>
|
|
|
|
<section id="related"><title>Modules apparentés et directives</title>
|
|
<related>
|
|
<modulelist>
|
|
<module>mod_cache_socache</module>
|
|
</modulelist>
|
|
<directivelist>
|
|
<directive module="mod_cache_disk">CacheRoot</directive>
|
|
<directive module="mod_cache_disk">CacheDirLevels</directive>
|
|
<directive module="mod_cache_disk">CacheDirLength</directive>
|
|
<directive module="mod_cache_disk">CacheMinFileSize</directive>
|
|
<directive module="mod_cache_disk">CacheMaxFileSize</directive>
|
|
<directive module="mod_cache_socache">CacheSocache</directive>
|
|
<directive module="mod_cache_socache">CacheSocacheMaxTime</directive>
|
|
<directive module="mod_cache_socache">CacheSocacheMinTime</directive>
|
|
<directive module="mod_cache_socache">CacheSocacheMaxSize</directive>
|
|
<directive module="mod_cache_socache">CacheSocacheReadSize</directive>
|
|
<directive module="mod_cache_socache">CacheSocacheReadTime</directive>
|
|
</directivelist>
|
|
</related>
|
|
</section>
|
|
|
|
<section id="sampleconf"><title>Exemple de configuration</title>
|
|
<example><title>Extrait de httpd.conf</title>
|
|
<highlight language="config">
|
|
#
|
|
# Exemple de configuration du cache
|
|
#
|
|
LoadModule cache_module modules/mod_cache.so
|
|
<IfModule mod_cache.c>
|
|
LoadModule cache_disk_module modules/mod_cache_disk.so
|
|
<IfModule mod_cache_disk.c>
|
|
CacheRoot c:/cacheroot
|
|
CacheEnable disk /
|
|
CacheDirLevels 5
|
|
CacheDirLength 3
|
|
</IfModule>
|
|
|
|
# Lorsqu'on sert de mandataire, on ne met pas en cache la liste
|
|
# des mises à jour de sécurité
|
|
CacheDisable http://security.update.server/update-list/
|
|
</IfModule>
|
|
</highlight>
|
|
</example>
|
|
</section>
|
|
|
|
<section id="thunderingherd"><title>Eviter une tempête de requête</title>
|
|
<p>Lorsqu'une entrée du cache est périmée, <module>mod_cache</module>
|
|
soumet une requête conditionnelle au processus d'arrière-plan, qui est
|
|
censé confirmer la validité de l'entrée du cache, ou dans la négative
|
|
envoyer une entrée mise à jour.</p>
|
|
<p>Un court mais non négligeable laps de temps existe entre le moment
|
|
où l'entrée du cache est périmée, et le moment où elle est mise à
|
|
jour. Sur un serveur fortement chargé, un certain nombre de requêtes
|
|
peut arriver pendant ce laps de temps, et provoquer une
|
|
<strong>tempête</strong> de requêtes susceptibles de saturer le
|
|
processus d'arrière-plan de manière soudaine et imprédictible.</p>
|
|
<p>Pour contenir cette tempête, on peut utiliser la directive
|
|
<directive>CacheLock</directive> afin de définir un répertoire où
|
|
seront créés <strong>à la volée</strong> des verrous pour les URLs.
|
|
Ces verrous sont utilisés comme autant d'<strong>indications</strong>
|
|
par les autres requêtes, soit pour empêcher une tentative de mise en
|
|
cache (un autre processus est en train de récupérer l'entité), soit
|
|
pour indiquer qu'une entrée périmée est en cours de mise à jour
|
|
(pendant ce temps, c'est le contenu périmé qui sera renvoyé).
|
|
</p>
|
|
<section>
|
|
<title>Mise en cache initiale d'une entrée</title>
|
|
<p>Lorsqu'une entité est mise en cache pour la première fois, un
|
|
verrou est créé pour cette entité jusqu'à ce que la réponse ait été
|
|
entièrement mise en cache. Pendant la durée de vie du verrou, le
|
|
cache va empêcher une seconde tentative de mise en cache de la même
|
|
entité. Bien que cela ne suffise pas à contenir la tempête de
|
|
requêtes, toute tentative de mettre en cache la même entité
|
|
plusieurs fois simultanément est stoppée.
|
|
</p>
|
|
</section>
|
|
<section>
|
|
<title>Mise à jour d'une entrée périmée</title>
|
|
<p>Lorsqu'une entrée atteint la limite de sa durée de vie, et
|
|
devient par conséquent périmée, un verrou est créé pour cette entité
|
|
jusqu'à ce que la réponse ait été soit confirmée comme encore
|
|
valide, soit remplacée par le processus d'arrière-plan. Pendant la
|
|
durée de vie du verrou, une seconde requête entrante va provoquer le
|
|
renvoi de la donnée périmée, et la tempête de requêtes sera
|
|
contenue.</p>
|
|
</section>
|
|
<section>
|
|
<title>Verrous et en-tête Cache-Control: no-cache</title>
|
|
<p>Les verrous ne sont utilisés <strong>qu'à titre
|
|
indicatif</strong> pour enjoindre le cache à être plus coopératif
|
|
avec les serveurs d'arrière-plan, et il est possible de passer outre
|
|
si nécessaire. Si le client envoie une requête contenant un en-tête
|
|
Cache-Control imposant un nouveau téléchargement de l'entité, tout
|
|
verrou éventuel sera ignoré, la requête du client sera honorée
|
|
immédiatement, et l'entrée du cache mise à jour.</p>
|
|
|
|
<p>Comme mécanisme de sécurité supplémentaire, la durée de vie
|
|
maximale des verrous est configurable. Lorsque cette limite est
|
|
atteinte, le verrou est supprimé et une autre requête peut alors en
|
|
créer un nouveau. Cette durée de vie peut être définie via la
|
|
directive <directive>CacheLockMaxAge</directive>, et sa valeur par
|
|
défaut est de 5 secondes.
|
|
</p>
|
|
</section>
|
|
<section>
|
|
<title>Exemple de configuration</title>
|
|
<example><title>Activation du verrouillage du cache</title>
|
|
<highlight language="config">
|
|
#
|
|
# Active le verrouillage du cache
|
|
#
|
|
<IfModule mod_cache.c>
|
|
CacheLock on
|
|
CacheLockPath /tmp/mod_cache-lock
|
|
CacheLockMaxAge 5
|
|
</IfModule>
|
|
</highlight>
|
|
</example>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="finecontrol"><title>Contrôle fin via le filtre CACHE</title>
|
|
<p>Dans son mode de fonctionnement par défaut, le cache s'exécute sous
|
|
la forme d'un gestionnaire rapide, court-circuitant la majorité des
|
|
traitements du serveur et fournissant ainsi une mise en cache
|
|
possédant les plus hautes performances disponibles.</p>
|
|
|
|
<p>Dans ce mode, le cache <strong>s'incruste</strong> devant le
|
|
serveur, comme si un mandataire de mise en cache indépendant RFC 2616
|
|
était placé devant ce dernier.</p>
|
|
|
|
<p>Bien que que ce mode offre les meilleures performances, les
|
|
administrateurs peuvent souhaiter, dans certaines circonstances,
|
|
effectuer des traitements sur la requête après que cette dernière ait
|
|
été mise en cache, comme ajouter du contenu personnalisé à la page
|
|
mise en cache, ou appliquer des restrictions d'autorisations au
|
|
contenu. Pour y parvenir, l'administrateur sera alors souvent forcé de
|
|
placer des serveurs mandataires inverses indépendants soit derrière,
|
|
soit devant le serveur de mise en cache.</p>
|
|
|
|
<p>Pour résoudre ce problème, la directive <directive
|
|
module="mod_cache">CacheQuickHandler</directive> peut être définie à
|
|
<strong>off</strong>, afin que le serveur traite toutes les phases
|
|
normalement exécutées par une requête non mise en cache, y compris les
|
|
phases <strong>d'authentification et d'autorisation</strong>.</p>
|
|
|
|
<p>En outre, l'administrateur peut éventuellement spécifier le
|
|
<strong>point précis dans la chaîne de filtrage</strong> où devra
|
|
intervenir la mise en cache en ajoutant le filtre
|
|
<strong>CACHE</strong> à la chaîne de filtrage en sortie.</p>
|
|
|
|
<p>Par exemple, pour mettre en cache le contenu avant d'appliquer une
|
|
compression à la réponse, placez le filtre <strong>CACHE</strong>
|
|
avant le filtre <strong>DEFLATE</strong> comme dans l'exemple suivant
|
|
:</p>
|
|
|
|
<highlight language="config">
|
|
# Mise en cache du contenu avant la compression optionnelle
|
|
CacheQuickHandler off
|
|
AddOutputFilterByType CACHE;DEFLATE text/plain
|
|
</highlight>
|
|
|
|
<p>Une autre possibilité consiste à mettre en cache le contenu avant
|
|
l'ajout de contenu personnalisé via <module>mod_include</module> (ou
|
|
tout autre filtre de traitement de contenu). Dans l'exemple suivant,
|
|
les modèles contenant des balises comprises par
|
|
<module>mod_include</module> sont mis en cache avant d'être
|
|
interprétés :</p>
|
|
|
|
<highlight language="config">
|
|
# Mise en cache du contenu avant l'intervention de mod_include et
|
|
# mod_deflate
|
|
CacheQuickHandler off
|
|
AddOutputFilterByType CACHE;INCLUDES;DEFLATE text/html
|
|
</highlight>
|
|
|
|
<p>Vous pouvez insérer le filtre <strong>CACHE</strong> en tout point
|
|
de la chaîne de filtrage. Dans l'exemple suivant, le contenu est mis
|
|
en cache après avoir été interprété par <module>mod_include</module>,
|
|
mais avant d'être traité par <module>mod_deflate</module> :</p>
|
|
|
|
<highlight language="config">
|
|
# Mise en cache du contenu entre les interventions de mod_include et
|
|
# mod_deflate
|
|
CacheQuickHandler off
|
|
AddOutputFilterByType INCLUDES;CACHE;DEFLATE text/html
|
|
</highlight>
|
|
|
|
<note type="warning"><title>Avertissement :</title>Si pour une raison
|
|
ou pour une autre, le point d'insertion du filtre
|
|
<strong>CACHE</strong> dans la chaîne de filtrage est modifié, vous
|
|
devez <strong>vider votre cache</strong> pour être sûr que les données
|
|
servies soient à jour. En effet, <module>mod_cache</module> n'est pas
|
|
en mesure d'effectuer cette opération à votre place.</note>
|
|
|
|
</section>
|
|
|
|
<section id="status"><title>Etat du cache et journalisation</title>
|
|
<p>Lorsque <module>mod_cache</module> a décidé s'il devait ou non
|
|
servir une entité depuis le cache, les raisons précises de cette
|
|
décision sont enregistrées dans l'environnement du sous-processus
|
|
interne à la requête sous la clé <strong>cache-status</strong>.
|
|
Cette information peut être journalisée via la directive <directive
|
|
module="mod_log_config">LogFormat</directive> comme suit :</p>
|
|
|
|
<highlight language="config">
|
|
LogFormat "%{cache-status}e ..."
|
|
</highlight>
|
|
|
|
<p>En fonction de la décision prise, l'information est aussi écrite
|
|
dans l'environnement du sous-processus sous une des quatre clés
|
|
suivantes :</p>
|
|
|
|
<dl>
|
|
<dt>cache-hit</dt><dd>Le contenu a été servi depuis le cache.</dd>
|
|
<dt>cache-revalidate</dt><dd>Le contenu du cache était périmé, a été
|
|
mis à jour avec succès, puis servi depuis le cache.</dd>
|
|
<dt>cache-miss</dt><dd>Le contenu n'était pas dans le cache et a été
|
|
servi directement depuis le serveur demandé.</dd>
|
|
<dt>cache-invalidate</dt><dd>L'entité du cache est devenue invalide
|
|
suite à une requête d'un type autre que GET ou HEAD.</dd>
|
|
</dl>
|
|
|
|
<p>Il est alors possible d'envisager une journalisation conditionnelle
|
|
du traitement des requêtes par rapport au cache comme dans l'exemple
|
|
suivant :</p>
|
|
|
|
<highlight language="config">
|
|
CustomLog "cached-requests.log" common env=cache-hit
|
|
CustomLog "uncached-requests.log" common env=cache-miss
|
|
CustomLog "revalidated-requests.log" common env=cache-revalidate
|
|
CustomLog "invalidated-requests.log" common env=cache-invalidate
|
|
</highlight>
|
|
|
|
<p>Pour les concepteurs de modules, une accroche (hook) nommée
|
|
<var>cache_status</var> est disponible et permet aux modules de
|
|
répondre aux résultats de la vérification du cache ci-dessus de manière
|
|
personnalisée.</p>
|
|
|
|
</section>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheEnable</name>
|
|
<description>Active la mise en cache des URLs spécifiées en utilisant le
|
|
gestionnaire de stockage précisé</description>
|
|
<syntax>CacheEnable <var>type de cache</var> [<var>chaîne
|
|
URL</var>]</syntax>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context>
|
|
</contextlist>
|
|
<compatibility>Une chaîne URL telle que '/' s'appliquait à tout contenu
|
|
en mandat direct dans les versions 2.2 et antérieures.</compatibility>
|
|
|
|
<usage>
|
|
<p>La directive <directive>CacheEnable</directive> enjoint
|
|
<module>mod_cache</module> de mettre en cache l'URL précisée par
|
|
<var>chaîne URL</var>, ainsi que les URLs de niveaux inférieurs. Le
|
|
gestionnaire de stockage du cache est spécifié à l'aide de
|
|
l'argument <var>type de cache</var>. La directive
|
|
<directive>CacheEnable</directive> peut être placée à l'intérieur d'une
|
|
section <directive type="section">Location</directive> ou <directive
|
|
type="section">LocationMatch</directive> pour indiquer que le
|
|
contenu considéré peut être mis en cache. Si <var>type de cache</var>
|
|
a pour valeur <code>disk</code>, <module>mod_cache</module>
|
|
utilisera le gestionnaire de stockage sur disque implémenté par
|
|
<module>mod_cache_disk</module>. Pour que <module>mod_cache</module>
|
|
utilise le gestionnaire de stockage basé sur le cache d'objets
|
|
partagés implémenté par <module>mod_cache_socache</module>,
|
|
spécifiez <code>socache</code> comme valeur du paramètre <var>type
|
|
de cache</var>.</p>
|
|
<p>Si les différentes directives <directive>CacheEnable</directive>
|
|
spécifient des URLs qui se recoupent (comme dans l'exemple
|
|
ci-dessous), tous les gestionnaires de stockage possibles seront
|
|
lancés, jusqu'au premier d'entre eux qui traitera effectivement la
|
|
requête.
|
|
L'ordre dans lequel les gestionnaires de stockage sont lancés est
|
|
déterminé par l'ordre dans lequel apparaissent les directives
|
|
<directive>CacheEnable</directive> dans le fichier de
|
|
configuration. Les directives <directive>CacheEnable</directive>
|
|
situées à l'intérieur de sections <directive
|
|
type="section">Location</directive> ou <directive
|
|
type="section">LocationMatch</directive> sont traitées avant les
|
|
directives <directive>CacheEnable</directive> définies au niveau
|
|
global.</p>
|
|
|
|
<p>En fonctionnement du type serveur mandataire direct, <var>chaîne
|
|
URL</var> doit au moins débuter par un protocole pour lequel la mise
|
|
en cache doit être activée.</p>
|
|
|
|
<highlight language="config">
|
|
# Mise en cache de contenu (gestionnaire normal seulement)
|
|
CacheQuickHandler off
|
|
<Location "/foo">
|
|
CacheEnable disk
|
|
</Location>
|
|
|
|
# Mise en cache via une expression rationnelle (gestionnaire normal seulement)
|
|
CacheQuickHandler off
|
|
<LocationMatch "foo$">
|
|
CacheEnable disk
|
|
</LocationMatch>
|
|
|
|
# Mise en cache de tous les contenus, à l'exception des URLs
|
|
# mandatées en direct (gestionnaire normal ou rapide)
|
|
CacheEnable disk /
|
|
|
|
# Mise en cache des URLs FTP mandatées (gestionnaire normal ou rapide)
|
|
CacheEnable disk ftp://
|
|
|
|
# Mise en cache des contenus mandatés en direct depuis www.example.org (gestionnaire normal ou rapide)
|
|
CacheEnable disk http://www.example.org/
|
|
</highlight>
|
|
|
|
<p>Un nom d'hôte commençant par un caractère <strong>"*"</strong>
|
|
correspondra à tout nom d'hôte se terminant par le suffixe
|
|
considéré. Un nom d'hôte commençant par un caractère
|
|
<strong>"."</strong> correspondra à tout nom d'hôte contenant le
|
|
composant de nom de domaine qui suit ce caractère.</p>
|
|
|
|
<highlight language="config">
|
|
# Correspond à www.example.org et fooexample.org
|
|
CacheEnable disk http://*example.org/
|
|
# Correspond à www.example.org, mais pas à fooexample.org
|
|
CacheEnable disk http://.example.org/
|
|
</highlight>
|
|
|
|
<p>Depuis la version 2.2.12, on peut définir la variable
|
|
d'environnement <code>no-cache</code> pour une définition plus fine
|
|
des ressources à mettre en cache.</p>
|
|
|
|
</usage>
|
|
<seealso><a href="../env.html">Les variables d'environnement dans
|
|
Apache</a></seealso>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheDisable</name>
|
|
<description>Désactive la mise en cache des URLs
|
|
spécifiées</description>
|
|
<syntax>CacheDisable <var>chaîne-url</var> | <var>on</var></syntax>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>La directive <directive>CacheDisable</directive> enjoint
|
|
<module>mod_cache</module> de <em>ne pas</em> mettre en cache l'URL
|
|
spécifiée par <var>chaîne URL</var>, ainsi que les URLs de niveaux
|
|
inférieurs.</p>
|
|
|
|
<example><title>Exemple</title>
|
|
<highlight language="config">
|
|
CacheDisable /fichiers_locaux
|
|
</highlight>
|
|
</example>
|
|
|
|
<p>Si la directive se trouve à l'intérieur d'une section <directive
|
|
type="section">Location</directive>, le chemin doit être spécifié en
|
|
dessous de la Location, et si le mot "on" est utilisé, la mise en
|
|
cache sera désactivée pour l'ensemble de l'arborescence concernée
|
|
par la section Location.</p>
|
|
|
|
<example><title>Exemple</title>
|
|
<highlight language="config">
|
|
<Location "/foo">
|
|
CacheDisable on
|
|
</Location>
|
|
</highlight>
|
|
</example>
|
|
|
|
<p>Avec les versions 2.2.12 et ultérieures, on peut définir la
|
|
variable d'environnement <code>no-cache</code> pour une définition
|
|
plus fine des ressources à mettre en cache.</p>
|
|
</usage>
|
|
<seealso><a href="../env.html">Les variables d'environnement dans
|
|
Apache</a></seealso>
|
|
</directivesynopsis>
|
|
<directivesynopsis>
|
|
<name>CacheMaxExpire</name>
|
|
<description>La durée maximale en secondes de mise en cache d'un
|
|
document</description>
|
|
<syntax>CacheMaxExpire <var>secondes</var></syntax>
|
|
<default>CacheMaxExpire 86400 (une journée)</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>La directive <directive>CacheMaxExpire</directive> permet de
|
|
spécifier le nombre maximum de secondes pendant lequel les documents
|
|
HTTP suceptibles d'être mis en cache seront conservés sans vérifier
|
|
leur contenu sur le serveur d'origine. Ce nombre de secondes
|
|
correspond donc à la durée maximale pendant laquelle un document ne
|
|
sera pas à jour. L'utilisation de cette valeur maximale est forcée,
|
|
même si le document possède une date d'expiration.</p>
|
|
|
|
<highlight language="config">
|
|
CacheMaxExpire 604800
|
|
</highlight>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheMinExpire</name>
|
|
<description>La durée minimale en secondes de mise en cache d'un
|
|
document</description>
|
|
<syntax>CacheMinExpire <var>secondes</var></syntax>
|
|
<default>CacheMinExpire 0</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>La directive <directive>CacheMaxExpire</directive> permet de
|
|
spécifier le nombre maximum de secondes pendant lequel les documents
|
|
HTTP suceptibles d'être mis en cache seront conservés sans vérifier
|
|
leur contenu sur le serveur d'origine. Elle n'est prise en compte
|
|
que dans le cas où le document ne possède aucune date d'expiration
|
|
valide.</p>
|
|
|
|
<highlight language="config">
|
|
CacheMinExpire 3600
|
|
</highlight>
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheDefaultExpire</name>
|
|
<description>La durée par défaut de mise en cache d'un document
|
|
lorsqu'aucune date d'expiration n'a été spécifiée.</description>
|
|
<syntax>CacheDefaultExpire <var>secondes</var></syntax>
|
|
<default>CacheDefaultExpire 3600 (une heure)</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>La directive <directive>CacheDefaultExpire</directive> permet de
|
|
spécifier un temps par défaut, en secondes, pendant lequel sera
|
|
conservé dans le cache un document qui ne possède ni date
|
|
d'expiration, ni date de dernière modification. La valeur de cette
|
|
directive est écrasée par la valeur de la directive
|
|
<directive>CacheMaxExpire</directive> si cette dernière est
|
|
utilisée.</p>
|
|
|
|
<highlight language="config">
|
|
CacheDefaultExpire 86400
|
|
</highlight>
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheIgnoreNoLastMod</name>
|
|
<description>Ignore le fait qu'une réponse ne possède pas d'en-tête Last
|
|
Modified.</description>
|
|
<syntax>CacheIgnoreNoLastMod On|Off</syntax>
|
|
<default>CacheIgnoreNoLastMod Off</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>Normalement, les documents qui ne possèdent pas de date de
|
|
dernière modification ne sont pas mis en cache. Dans certaines
|
|
circonstances, la date de dernière modification est supprimée (au
|
|
cours des traitements liés à <module>mod_include</module> par
|
|
exemple), ou n'existe tout simplement pas. La directive
|
|
<directive>CacheIgnoreNoLastMod</directive> permet de spécifier si
|
|
les documents ne possèdant pas de date de dernière modification
|
|
doivent être mis en cache, même sans date de dernière modification.
|
|
Si le document ne possède ni date d'expiration, ni date de dernière
|
|
modification, la valeur spécifiée par la directive
|
|
<directive>CacheDefaultExpire</directive> servira à générer une date
|
|
d'expiration.
|
|
</p>
|
|
|
|
<highlight language="config">
|
|
CacheIgnoreNoLastMod On
|
|
</highlight>
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheIgnoreCacheControl</name>
|
|
<description>Ignore les en-têtes de requête enjoignant de ne pas servir
|
|
le contenu au client depuis le cache</description>
|
|
<syntax>CacheIgnoreCacheControl On|Off</syntax>
|
|
<default>CacheIgnoreCacheControl Off</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>Normalement, les requêtes contenant des en-têtes tels que
|
|
Cache-Control: no-cache ou Pragma: no-cache ne sont pas servies
|
|
depuis le cache. La directive
|
|
<directive>CacheIgnoreCacheControl</directive> permet de modifier ce
|
|
comportement. Avec <directive>CacheIgnoreCacheControl
|
|
On</directive>, le serveur tentera de servir la ressource depuis le
|
|
cache, même si la requête contient un en-tête
|
|
no-cache.</p>
|
|
|
|
<highlight language="config">
|
|
CacheIgnoreCacheControl On
|
|
</highlight>
|
|
|
|
<note type="warning"><title>Avertissement :</title>
|
|
Cette directive permet de servir des ressources depuis le cache,
|
|
même si le client a demandé à ce qu'il n'en soit pas ainsi. Le
|
|
contenu servi est ainsi susceptible d'être périmé.
|
|
</note>
|
|
</usage>
|
|
<seealso><directive module="mod_cache">CacheStorePrivate</directive></seealso>
|
|
<seealso><directive module="mod_cache">CacheStoreNoStore</directive></seealso>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheIgnoreQueryString</name>
|
|
<description>Ignore la chaîne de paramètres lors de la mise en
|
|
cache</description>
|
|
<syntax>CacheIgnoreQueryString On|Off</syntax>
|
|
<default>CacheIgnoreQueryString Off</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>Normalement, les requêtes comportant une chaîne de paramètres
|
|
sont mises en cache séparément si leurs chaînes de paramètres
|
|
diffèrent.
|
|
En accord avec la RFC 2616/13.9, cette mise en cache n'est effectuée
|
|
séparément que si une date d'expiration est spécifiée. La directive
|
|
<directive>CacheIgnoreQueryString</directive> permet la mise en
|
|
cache de requêtes même si aucune date d'expiration est spécifiée, et
|
|
de renvoyer une réponse depuis la cache même si les chaînes de
|
|
paramètres diffèrent. Du point de vue du cache, la requête est
|
|
traitée comme si elle ne possèdait pas de chaîne de paramètres
|
|
lorsque cette directive est activée.</p>
|
|
|
|
<highlight language="config">
|
|
CacheIgnoreQueryString On
|
|
</highlight>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheLastModifiedFactor</name>
|
|
<description>Le facteur utilisé pour générer une date d'expiration en
|
|
fonction de la date de dernière modification.</description>
|
|
<syntax>CacheLastModifiedFactor <var>flottant</var></syntax>
|
|
<default>CacheLastModifiedFactor 0.1</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>Si un document ne possède pas de date d'expiration, elle peut
|
|
être calculée en fonction de la date de dernière modification, si
|
|
elle existe. La directive
|
|
<directive>CacheLastModifiedFactor</directive> permet de spécifier
|
|
un <var>facteur</var> à utiliser pour la génération de cette date
|
|
d'expiration au sein de la formule suivante :
|
|
|
|
<code>délai-expiration = durée-depuis-date-dernière-modification *
|
|
<var>facteur</var>
|
|
date-expiration = date-courante + délai-expiration</code>
|
|
|
|
Par exemple, si la dernière modification du document date de 10
|
|
heures, et si <var>facteur</var> a pour valeur 0.1, le délai
|
|
d'expiration sera de 10*0.1 = 1 heure. Si l'heure courante est
|
|
3:00pm, la date d'expiration calculée sera 3:00pm + 1 heure =
|
|
4:00pm.
|
|
|
|
Si le délai d'expiration est supérieur à celui spécifié par la
|
|
directive <directive>CacheMaxExpire</directive>, c'est ce dernier
|
|
qui l'emporte.</p>
|
|
|
|
<highlight language="config">
|
|
CacheLastModifiedFactor 0.5
|
|
</highlight>
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheIgnoreHeaders</name>
|
|
<description>Ne pas stocker le(s) en-tête(s) spécifié(s) dans le cache.
|
|
</description>
|
|
<syntax>CacheIgnoreHeaders <var>en-tête</var> [<var>en-tête</var>] ...</syntax>
|
|
<default>CacheIgnoreHeaders None</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>En accord avec la RFC 2616, les en-têtes HTTP hop-by-hop ne sont
|
|
pas stockés dans le cache. Les en-têtes HTTP suivant sont des
|
|
en-têtes hop-by-hop, et en tant que tels, ne sont en <em>aucun</em>
|
|
cas stockés dans le cache, quelle que soit la définition de la
|
|
directive <directive>CacheIgnoreHeaders</directive> :</p>
|
|
|
|
<ul>
|
|
<li><code>Connection</code></li>
|
|
<li><code>Keep-Alive</code></li>
|
|
<li><code>Proxy-Authenticate</code></li>
|
|
<li><code>Proxy-Authorization</code></li>
|
|
<li><code>TE</code></li>
|
|
<li><code>Trailers</code></li>
|
|
<li><code>Transfer-Encoding</code></li>
|
|
<li><code>Upgrade</code></li>
|
|
</ul>
|
|
|
|
<p>La directive <directive>CacheIgnoreHeaders</directive> permet de
|
|
spécifier quels en-têtes HTTP ne doivent pas être stockés dans le
|
|
cache. Par exemple, il peut s'avérer pertinent dans certains cas de
|
|
ne pas stocker les cookies dans le cache.</p>
|
|
|
|
<p>La directive <directive>CacheIgnoreHeaders</directive> accepte
|
|
une liste d'en-têtes HTTP séparés par des espaces, qui ne doivent
|
|
pas être stockés dans le cache. Si les en-têtes hop-by-hop sont les
|
|
seuls à ne pas devoir être stockés dans le cache (le comportement
|
|
compatible RFC 2616), la directive
|
|
<directive>CacheIgnoreHeaders</directive> peut être définie à
|
|
<code>None</code>.</p>
|
|
|
|
<example><title>Exemple 1</title>
|
|
<highlight language="config">
|
|
CacheIgnoreHeaders Set-Cookie
|
|
</highlight>
|
|
</example>
|
|
|
|
<example><title>Exemple 2</title>
|
|
<highlight language="config">
|
|
CacheIgnoreHeaders None
|
|
</highlight>
|
|
</example>
|
|
|
|
<note type="warning"><title>Avertissement :</title>
|
|
Si des en-têtes nécessaires à la bonne gestion du cache, comme
|
|
<code>Expires</code>, ne sont pas stockés suite à la définition
|
|
d'une directive <directive>CacheIgnoreHeaders</directive>, le
|
|
comportement de mod_cache sera imprévisible.
|
|
</note>
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheIgnoreURLSessionIdentifiers</name>
|
|
<description>Ignore les identifiants de session définis encodés dans
|
|
l'URL lors de la mise en cache
|
|
</description>
|
|
<syntax>CacheIgnoreURLSessionIdentifiers <var>identifiant</var>
|
|
[<var>identifiant</var>] ...</syntax>
|
|
<default>CacheIgnoreURLSessionIdentifiers None</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>Certaines applications encodent l'identifiant de session dans
|
|
l'URL comme dans l'exemple suivant :
|
|
</p>
|
|
<ul>
|
|
<li><code>/une-application/image.gif;jsessionid=123456789</code></li>
|
|
<li><code>/une-application/image.gif?PHPSESSIONID=12345678</code></li>
|
|
</ul>
|
|
<p>Ceci implique la mise en cache des ressources séparément pour
|
|
chaque session, ce qui n'est en général pas souhaité. La directive
|
|
<directive>CacheIgnoreURLSessionIdentifiers</directive> permet de
|
|
définir une liste d'identifiants qui seront supprimés de la clé
|
|
utilisée pour identifier une entité dans le cache, de façon à ce que
|
|
les ressources ne soient pas stockées séparément pour chaque
|
|
session.
|
|
</p>
|
|
<p><code>CacheIgnoreURLSessionIdentifiers None</code> vide la liste
|
|
des identifiants ignorés. Autrement, chaque identifiant spécifié est
|
|
ajouté à la liste.</p>
|
|
|
|
<example><title>Exemple 1</title>
|
|
<highlight language="config">
|
|
CacheIgnoreURLSessionIdentifiers jsessionid
|
|
</highlight>
|
|
</example>
|
|
|
|
<example><title>Exemple 2</title>
|
|
<highlight language="config">
|
|
CacheIgnoreURLSessionIdentifiers None
|
|
</highlight>
|
|
</example>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheStoreExpired</name>
|
|
<description>Tente de mettre en cache les réponses que le serveur
|
|
considère comme arrivées à expiration</description>
|
|
<syntax>CacheStoreExpired On|Off</syntax>
|
|
<default>CacheStoreExpired Off</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>Depuis la version 2.2.4, les réponses qui sont arrivées à
|
|
expiration ne sont pas stockées dans le cache. La directive
|
|
<directive>CacheStoreExpired</directive> permet de modifier ce
|
|
comportement. Avec <directive>CacheStoreExpired</directive> On, le
|
|
serveur tente de mettre en cache la ressource si elle est périmée.
|
|
Les requêtes suivantes vont déclencher une requête si-modifié-depuis
|
|
de la part du serveur d'origine, et la réponse sera renvoyée à
|
|
partir du cache si la ressource d'arrière-plan n'a pas été modifiée.</p>
|
|
|
|
<highlight language="config">
|
|
CacheStoreExpired On
|
|
</highlight>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheStorePrivate</name>
|
|
<description>Tente de mettre en cache des réponses que le serveur a
|
|
marquées comme privées</description>
|
|
<syntax>CacheStorePrivate On|Off</syntax>
|
|
<default>CacheStorePrivate Off</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>Normalement, les réponse comportant un en-tête Cache-Control:
|
|
dont la valeur est private ne seront pas stockées dans le cache. La
|
|
directive <directive>CacheStorePrivate</directive> permet de
|
|
modifier ce comportement. Si
|
|
<directive>CacheStorePrivate</directive> est définie à On, le
|
|
serveur tentera de mettre la ressource en cache, même si elle
|
|
contient un en-tête private.</p>
|
|
|
|
|
|
<highlight language="config">
|
|
CacheStorePrivate On
|
|
</highlight>
|
|
|
|
|
|
<note type="warning"><title>Avertissement :</title>
|
|
Cette directive autorise la mise en cache même si le serveur
|
|
indique que la ressource ne doit pas être mise en cache. Elle
|
|
n'est de ce fait appropriée que dans le cas d'un cache
|
|
'privé'.
|
|
</note>
|
|
</usage>
|
|
<seealso><directive module="mod_cache">CacheIgnoreCacheControl</directive></seealso>
|
|
<seealso><directive module="mod_cache">CacheStoreNoStore</directive></seealso>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheStoreNoStore</name>
|
|
<description>Tente de mettre en cache les requêtes ou réponses dont
|
|
l'entête Cache-Control: a pour valeur no-store.</description>
|
|
<syntax>CacheStoreNoStore On|Off</syntax>
|
|
<default>CacheStoreNoStore Off</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
<context>directory</context><context>.htaccess</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>Normalement, les requêtes ou réponses dont l'en-tête
|
|
Cache-Control: a pour valeur no-store ne sont pas stockées dans le
|
|
cache. La directive <directive>CacheStoreNoStore</directive> permet
|
|
de modifier ce comportement. Si
|
|
<directive>CacheStoreNoStore</directive> est définie à On, le
|
|
serveur tente de mettre la ressource en cache même si elle contient
|
|
un en-tête no-store.</p>
|
|
|
|
|
|
<highlight language="config">
|
|
CacheStoreNoStore On
|
|
</highlight>
|
|
|
|
|
|
<note type="warning"><title>Avertissement :</title>
|
|
Selon la RFC 2616, la valeur d'en-tête no-store est censée
|
|
"prévenir la suppression ou la rétention par inadvertance
|
|
d'informations sensibles (par exemple, sur des bandes de
|
|
sauvegarde)". Autrement dit, l'activation de la directive
|
|
<directive>CacheStoreNoCache</directive> pourrait provoquer le
|
|
stockage d'informations sensibles dans le cache. Vous avez donc
|
|
été prévenus.
|
|
</note>
|
|
</usage>
|
|
<seealso><directive module="mod_cache">CacheIgnoreCacheControl</directive></seealso>
|
|
<seealso><directive module="mod_cache">CacheStorePrivate</directive></seealso>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheLock</name>
|
|
<description>Active la protection contre les tempêtes de requêtes.</description>
|
|
<syntax>CacheLock <var>on|off</var></syntax>
|
|
<default>CacheLock off</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>La directive <directive>CacheLock</directive> active la protection
|
|
contre les tempêtes de requêtes pour l'espace d'adressage donné.</p>
|
|
|
|
<p>La configuration minimale pour activer le verrouillage contre les
|
|
tempêtes de requêtes dans le répertoire par
|
|
défaut des fichiers run-time est
|
|
la suivante :</p>
|
|
|
|
<highlight language="config">
|
|
# Active le verrouillage du cache
|
|
CacheLock on
|
|
</highlight>
|
|
|
|
<p>Les verrous sont des fichiers vides qui n'existent que pour les
|
|
URLs présentes dont le contenu est périmé ; ils consomment dont bien
|
|
moins de ressources que le cache disque traditionnel.</p>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheLockPath</name>
|
|
<description>Définit le répertoire des verrous.</description>
|
|
<syntax>CacheLockPath <var>répertoire</var></syntax>
|
|
<default>CacheLockPath mod_cache-lock</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>La directive <directive>CacheLockPath</directive> permet de
|
|
spécifier le répertoire dans lequel les verrous sont
|
|
créés. Si <var>répertoire</var> n'est pas un
|
|
chemin absolu, il sera relatif au répertoire défini par la directive
|
|
<directive module="core">DefaultRuntimeDir</directive>.</p>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheLockMaxAge</name>
|
|
<description>Définit la durée de vie maximale d'un verrou de cache.</description>
|
|
<syntax>CacheLockMaxAge <var>entier</var></syntax>
|
|
<default>CacheLockMaxAge 5</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
</contextlist>
|
|
|
|
<usage>
|
|
<p>La directive <directive>CacheLockMaxAge</directive> permet de
|
|
spécifier la durée de vie maximale d'un verrou de cache.</p>
|
|
|
|
<p>Un verrou plus ancien que cette valeur exprimée en secondes sera
|
|
ignoré, et la prochaine requête entrante sera alors en mesure de
|
|
recréer le verrou. Ce mécanisme permet d'éviter les mises à jour trop
|
|
longues initiées par des clients lents.</p>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheQuickHandler</name>
|
|
<description>Exécute le cache à partir d'un gestionnaire rapide.</description>
|
|
<syntax>CacheQuickHandler <var>on|off</var></syntax>
|
|
<default>CacheQuickHandler on</default>
|
|
<contextlist><context>server config</context><context>virtual host</context>
|
|
</contextlist>
|
|
<compatibility>Disponible à partir de la version 2.3.3 du serveur HTTP
|
|
Apache</compatibility>
|
|
|
|
<usage>
|
|
<p>La directive <directive
|
|
module="mod_cache">CacheQuickHandler</directive> permet de contrôler
|
|
la phase au cours de laquelle la mise en cache est effectuée.</p>
|
|
|
|
<p>Avec la configuration par défaut, le cache agit au cours de la
|
|
phase du gestionnaire rapide. Cette phase court-circuite la majorité
|
|
des traitements du serveur, et constitue le mode d'opération le plus
|
|
performant pour un serveur typique. Le cache
|
|
<strong>s'incruste</strong> devant le serveur, et la majorité des
|
|
traitements du serveur est court-circuitée.</p>
|
|
|
|
<p>Lorsque cette directive est définie à off, le cache agit comme un
|
|
gestionnaire normal, et est concerné par toutes les phases de
|
|
traitement d'une requête. Bien que ce mode soit moins performant que
|
|
le mode par défaut, il permet d'utiliser le cache dans les cas où un
|
|
traitement complet de la requête est nécessaire, comme par exemple
|
|
lorsque le contenu est soumis à autorisation.</p>
|
|
|
|
<highlight language="config">
|
|
# Exécute le cache comme un gestionnaire normal
|
|
CacheQuickHandler off
|
|
</highlight>
|
|
|
|
<p>Lorsque le gestionnaire rapide est désactivé, l'administrateur a
|
|
aussi la possibilité de choisir avec précision le point de la chaîne
|
|
de filtrage où la mise en cache sera effectuée, en utilisant le
|
|
filtre <strong>CACHE</strong>.</p>
|
|
|
|
<highlight language="config">
|
|
# Mise en cache du contenu avant l'intervention de mod_include et
|
|
# mod_deflate
|
|
CacheQuickHandler off
|
|
AddOutputFilterByType CACHE;INCLUDES;DEFLATE text/html
|
|
</highlight>
|
|
|
|
<p>Si le filtre CACHE est spécifié plusieurs fois, c'est la dernière
|
|
instance qui sera prise en compte.</p>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheHeader</name>
|
|
<description>Ajoute un en-tête X-Cache à la réponse.</description>
|
|
<syntax>CacheHeader <var>on|off</var></syntax>
|
|
<default>CacheHeader off</default>
|
|
<contextlist><context>server config</context>
|
|
<context>virtual host</context>
|
|
<context>directory</context>
|
|
<context>.htaccess</context>
|
|
</contextlist>
|
|
<compatibility>Disponible depuis la version 2.3.9 d'Apache</compatibility>
|
|
|
|
<usage>
|
|
<p>Lorsque la directive <directive
|
|
module="mod_cache">CacheHeader</directive> est définie à on, un
|
|
en-tête <strong>X-Cache</strong> est ajouté à la réponse et contient
|
|
l'état du cache pour cette dernière. Si le gestionnaire normal est
|
|
utilisé, cette directive peut se situer dans une section
|
|
<directive type="section" module="core">Directory</directive> ou
|
|
<directive type="section" module="core">Location</directive>. Si c'est
|
|
le
|
|
gestionnaire rapide qui est utilisé, elle doit se situer dans un
|
|
contexte de serveur principal ou de serveur virtuel, sinon elle sera
|
|
ignorée.</p>
|
|
|
|
<dl>
|
|
<dt><strong>HIT</strong></dt><dd>Le contenu était à jour et a été
|
|
servi depuis le cache.</dd>
|
|
<dt><strong>REVALIDATE</strong></dt><dd>Le contenu était périmé, a
|
|
été mis à jour, puis a été servi depuis le cache.</dd>
|
|
<dt><strong>MISS</strong></dt><dd>Le contenu n'a pas été servi
|
|
depuis le cache, mais directement depuis le serveur demandé.</dd>
|
|
</dl>
|
|
|
|
<highlight language="config">
|
|
# Active l'en-tête X-Cache
|
|
CacheHeader on
|
|
</highlight>
|
|
|
|
<highlight language="config">
|
|
X-Cache: HIT from localhost
|
|
</highlight>
|
|
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheDetailHeader</name>
|
|
<description>Ajoute un en-tête X-Cache-Detail à la réponse.</description>
|
|
<syntax>CacheDetailHeader <var>on|off</var></syntax>
|
|
<default>CacheDetailHeader off</default>
|
|
<contextlist><context>server config</context>
|
|
<context>virtual host</context>
|
|
<context>directory</context>
|
|
<context>.htaccess</context>
|
|
</contextlist>
|
|
<compatibility>Disponible depuis la version 2.3.9 d'Apache</compatibility>
|
|
|
|
<usage>
|
|
<p>Lorsque la directive <directive
|
|
module="mod_cache">CacheDetailHeader</directive> est définie à on, un
|
|
en-tête <strong>X-Cache-Detail</strong> est ajouté à la réponse et
|
|
contient les raisons précises d'une décision d'utilisation du cache
|
|
vis à vis de cette dernière.</p>
|
|
|
|
<p>Ceci peut s'avérer utile au cours du développement de services
|
|
RESTful mis en cache pour obtenir des informations supplémentaires à
|
|
propos des décisions vis à vis du cache écrites dans les en-têtes de
|
|
la réponse. Il est ainsi possible de vérifier si
|
|
<code>Cache-Control</code> et d'autres en-têtes ont été correctement
|
|
utilisés par le service et le client.</p>
|
|
|
|
<p>Si le gestionnaire normal est utilisé, cette directive peut se
|
|
situer dans une section <directive type="section"
|
|
module="core">Directory</directive> ou <directive type="section"
|
|
module="core">Location</directive>. Si c'est le gestionnaire
|
|
rapide qui est utilisé, elle doit se situer dans un contexte de
|
|
serveur principal ou de serveur virtuel, sinon elle sera ignorée.</p>
|
|
|
|
<highlight language="config">
|
|
# Active l'en-tête X-Cache-Detail
|
|
CacheDetailHeader on
|
|
</highlight>
|
|
|
|
<example>
|
|
X-Cache-Detail: "conditional cache hit: entity refreshed" from localhost<br />
|
|
</example>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheKeyBaseURL</name>
|
|
<description>Remplace l'URL de base des clés du cache mandatées en
|
|
inverse</description>
|
|
<syntax>CacheKeyBaseURL <var>URL</var></syntax>
|
|
<default>CacheKeyBaseURL http://example.com</default>
|
|
<contextlist><context>server config</context>
|
|
<context>virtual host</context>
|
|
</contextlist>
|
|
<compatibility>Disponible depuis la version 2.3.9 d'Apache</compatibility>
|
|
|
|
<usage>
|
|
<p>Lorsque la directive <directive
|
|
module="mod_cache">CacheKeyBaseURL</directive> est utilisée, l'URL
|
|
spécifiée sera utilisée comme URL de base pour calculer l'URL des clés
|
|
du cache dans la configuration du mandataire inverse. Par défaut,
|
|
c'est le protocole/nom d'hôte/port du serveur virtuel courant qui sera
|
|
utilisé pour construire la clé de cache. Dans le cas d'un cluster de
|
|
machines, si toutes les entrées du cache doivent posséder la même clé,
|
|
cette directive permet de spécifier une nouvelle URL de base.</p>
|
|
|
|
<highlight language="config">
|
|
# Remplace l'URL de base de la clé de cache.
|
|
CacheKeyBaseURL http://www.example.com/
|
|
</highlight>
|
|
|
|
<note type="warning">Prenez garde en définissant cette directive. Si
|
|
deux serveurs virtuels distincts possèdent accidentellement la même
|
|
URL de base, les entrées en provenance d'un serveur virtuel seront
|
|
servies par l'autre.</note>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
<directivesynopsis>
|
|
<name>CacheStaleOnError</name>
|
|
<description>Sert du contenu non à jour à la place de réponses 5xx.</description>
|
|
<syntax>CacheStaleOnError <var>on|off</var></syntax>
|
|
<default>CacheStaleOnError on</default>
|
|
<contextlist><context>server config</context>
|
|
<context>virtual host</context>
|
|
<context>directory</context>
|
|
<context>.htaccess</context>
|
|
</contextlist>
|
|
<compatibility>Disponible depuis la version 2.3.9 d'Apache</compatibility>
|
|
|
|
<usage>
|
|
<p>Lorsque la directive <directive
|
|
module="mod_cache">CacheStaleOnError</directive> est définie à on, et
|
|
si des données non mises à jour sont disponibles dans le cache, ce
|
|
dernier renverra ces données, plutôt qu'une éventuelle réponse 5xx en
|
|
provenance du serveur d'arrière-plan. Alors que l'en-tête
|
|
Cache-Control envoyé par les clients sera respecté, et que les clients
|
|
recevront donc dans ce cas la réponse 5xx brute à leur requête, cette
|
|
réponse 5xx renvoyée au client n'invalidera pas le contenu dans le
|
|
cache. </p>
|
|
|
|
<highlight language="config">
|
|
# Sert des données non mises à jour en cas d'erreur.
|
|
CacheStaleOnError on
|
|
</highlight>
|
|
|
|
</usage>
|
|
</directivesynopsis>
|
|
|
|
</modulesynopsis>
|