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