mirror of
				https://github.com/apache/httpd.git
				synced 2025-10-31 19:10:37 +03:00 
			
		
		
		
	git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1519189 13f79535-47bb-0310-9956-ffa450edef68
		
			
				
	
	
		
			1212 lines
		
	
	
		
			55 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			1212 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 : 1517405 -->
 | |
| <!-- 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 un module de gestion de stockage :</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>
 | |
| 
 | |
| <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> peut aussi être utilisé pour spécifier des sites distants
 | |
|     et des protocoles de mandat pour lesquels la mise en cache devra
 | |
|     ê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 des URLs mandatées (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 situés dans 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
 | |
|   module="core"><Directory></directive> ou <directive
 | |
|   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
 | |
|   module="core"><Directory></directive> ou <directive
 | |
|   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>
 |