]> granicus.if.org Git - apache/blobdiff - docs/manual/caching.xml.fr
Help doc writer to spot places where:
[apache] / docs / manual / caching.xml.fr
index 9b1d7e3ba19f87316e4da26984eef7115b989495..412cf7a48fd942ec07ddaf87049966e31b5cf327 100644 (file)
@@ -1,9 +1,9 @@
-<?xml version="1.0" encoding="ISO-8859-1" ?>
+<?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE manualpage SYSTEM "style/manualpage.dtd">
 <?xml-stylesheet type="text/xsl" href="style/manual.fr.xsl"?>
 <!-- French translation : Lucien GENTIS -->
 <!-- Reviewed by : Vincent Deffontaines -->
-<!-- English Revision : 1174747 -->
+<!-- English Revision: 1836060 -->
 
 <!--
  Licensed to the Apache Software Foundation (ASF) under one or more
   <title>Guide de la mise en cache</title>
 
   <summary>
-    <p>Ce document compl&egrave;te la documentation de r&eacute;f&eacute;rence des modules
+    <p>Ce document complète la documentation de référence des modules
     <module>mod_cache</module>, <module>mod_cache_disk</module>,
     <module>mod_file_cache</module> et du programme <a
     href="programs/htcacheclean.html">htcacheclean</a>.
-    Il d&eacute;crit l'utilisation des fonctionnalit&eacute;s de mise en
+    Il décrit l'utilisation des fonctionnalités de mise en
     cache du serveur HTTP Apache
-    pour acc&eacute;l&eacute;rer les services web et proxy, tout en &eacute;vitant les probl&egrave;mes
+    pour accélérer les services web et proxy, tout en évitant les problèmes
     courants et les erreurs de configuration.</p>
   </summary>
 
   <section id="introduction">
     <title>Introduction</title>
 
-    <p>Depuis la version 2.2 du serveur HTTP Apache, les modules
-    <module>mod_cache</module>
-    et <module>mod_file_cache</module> ne sont plus jug&eacute;s exp&eacute;rimentaux
-    et on consid&egrave;re qu'ils peuvent &ecirc;tre utilis&eacute;s en production. Ces
-    architectures de mise en cache constituent un puissant concept
-    d'acc&eacute;l&eacute;ration de la gestion HTTP, tant comme serveur web originel
-    que comme mandataire.</p>
-
-    <p>Le module <module>mod_cache</module> et son module de soutien
-    <module>mod_cache_disk</module>
-    permettent une mise en cache intelligente du point de vue HTTP.
-    Le contenu proprement dit est stock&eacute; dans le cache,
-    et mod_cache tente d'honorer tous les en-t&ecirc;tes HTTP et les options
-    qui d&eacute;finissent la possibilit&eacute; de mise en cache du contenu. Il g&egrave;re non
-    seulement le contenu local, mais aussi le contenu mandat&eacute;.
-    <module>mod_cache</module>
-    est con&ccedil;u pour des configurations de mise en cache simples ou complexes,
-    dans lesquels vous traitez de contenu mandat&eacute;, de contenu local dynamique
-    ou avez besoin d'acc&eacute;l&eacute;rer l'acc&egrave;s &agrave; des fichiers locaux qui sont modifi&eacute;s
-    au cours du temps.</p>
-
-    <p>Le module <module>mod_file_cache</module> quant &agrave; lui, constitue une
-    forme de mise en cache plus basique, mais quelques fois int&eacute;ressante.
-    Plut&ocirc;t que de g&eacute;rer la complexit&eacute; de s'assurer de mani&egrave;re active de la
-    possibilit&eacute; de mise en cache d'URLs,
-    <module>mod_file_cache</module> fournit des m&eacute;thodes pour la gestion
-    et l'&eacute;dition de fichiers en m&eacute;moire afin de maintenir un cache de fichiers
-    dans l'&eacute;tat o&ugrave; ils &eacute;taient la derni&egrave;re
-    fois qu'httpd a d&eacute;marr&eacute;.
-    En tant que tel, <module>mod_file_cache</module> a &eacute;t&eacute; con&ccedil;u pour am&eacute;liorer
-    le temps d'acc&egrave;s &agrave; des fichiers locaux statiques qui ne sont modifi&eacute;s
-    que rarement.</p>
-
-    <p>Etant donn&eacute; que <module>mod_file_cache</module> constitue une
-    impl&eacute;mentation de mise en cache relativement simple, mises &agrave; part les
-    sections sp&eacute;cifiques sur les directives <directive
-    module="mod_file_cache">CacheFile</directive> et <directive
-    module="mod_file_cache">MMapFile</directive>, les explications fournies
-    dans ce guide concernent l'architecture de mise en cache du
-    module <module>mod_cache</module>.</p>
+    <p>Le serveur HTTP Apache offre tout un ensemble de fonctionnalités
+    de mise en cache qui ont été conçues pour améliorer les performances
+    du serveur de différentes manières.</p>
+
+    <dl>
+        <dt>Mise en cache HTTP à trois états RFC2616</dt>
+        <dd><module>mod_cache</module> et son module de fournisseur
+       <module>mod_cache_disk</module> proposent une mise en cache
+       intelligente de niveau HTTP. Le contenu proprement dit est
+       stocké dans le cache, et mod_cache vise à respecter tous les
+       en-têtes HTTP, ainsi que les options qui contrôlent la mise en
+       cache du contenu comme décrit dans la <a
+       href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html">Section
+       13 de la RFC2616</a>. <module>mod_cache</module> peut gérer des
+       configurations de mise en cache simples, mais aussi complexes
+       comme dans les cas où vous avez à faire à des contenus mandatés,
+       à des contenus locaux dynamiques, ou lorsque vous avez besoin
+       d'accélérer l'accès aux fichiers locaux situés sur disque
+       supposé lent.
+        </dd>
+
+        <dt>Mise en cache d'objets partagés de forme clé/valeur à deux
+       états</dt>
+        <dd>
+            L'<a href="socache.html">API du cache d'objets partagés</a> (socache)
+           et ses modules de fournisseurs
+           proposent une mise en cache d'objets partagés à base de
+           couples clé/valeur de niveau serveur. Ces modules sont
+           conçus pour la mise en cache de données de bas niveau comme
+           les sessions SSL et les données d'authentification. les
+           serveurs d'arrière-plan permettent le stockage des données
+           au niveau serveur en mémoire partagée, ou au niveau
+           datacenter dans un cache comme memcache ou distcache.
+        </dd>
+
+        <dt>Mise en cache de fichiers spécialisée</dt>
+        <dd>
+            <module>mod_file_cache</module> offre la possibilité de
+           précharger des fichiers en mémoire au démarrage du serveur,
+           et peut améliorer les temps d'accès et sauvegarder les
+           gestionnaires de fichiers pour les fichiers qui font l'objet
+           d'accès fréquents, évitant ainsi d'avoir à accéder au disque
+           à chaque requête.
+        </dd>
+    </dl>
 
     <p>Pour tirer parti efficacement de ce document, les bases de HTTP doivent
-    vous &ecirc;tre famili&egrave;res, et vous devez avoir lu les sections
+    vous être familières, et vous devez avoir lu les sections
     <a href="urlmapping.html">Mise en correspondance des
-    URLs avec le syst&egrave;me de fichiers</a> et
-    <a href="content-negotiation.html">N&eacute;gociation sur le contenu</a>
+    URLs avec le système de fichiers</a> et
+    <a href="content-negotiation.html">Négociation sur le contenu</a>
     du guide de l'utilisateur.</p>
 
   </section>
 
-  <section id="overview">
+  <section id="http-caching">
 
-    <title>Vue d'ensemble de la mise en cache</title>
+    <title>Mise en cache HTTP à trois états RFC2616</title>
 
     <related>
       <modulelist>
         <module>mod_cache</module>
         <module>mod_cache_disk</module>
-        <module>mod_file_cache</module>
       </modulelist>
       <directivelist>
         <directive module="mod_cache">CacheEnable</directive>
         <directive module="mod_cache">CacheDisable</directive>
-        <directive module="mod_file_cache">CacheFile</directive>
-        <directive module="mod_file_cache">MMapFile</directive>
         <directive module="core">UseCanonicalName</directive>
         <directive module="mod_negotiation">CacheNegotiatedDocs</directive>
       </directivelist>
     </related>
 
-    <p><module>mod_cache</module> peut faire intervenir deux phases
-    principales pendant la dur&eacute;e de vie d'une requ&ecirc;te.
-    En premier lieu, <module>mod_cache</module>
-    est un module de mise en correspondance d'URLs, ce qui signifie que si
-    une URL a &eacute;t&eacute; mise en cache, et que la version du cache de cette URL n'est
-    pas arriv&eacute;e &agrave; expiration, la requ&ecirc;te sera trait&eacute;e directement par
-    <module>mod_cache</module>.</p>
-
-    <p>Ceci entra&icirc;ne que toutes autres actions qui se d&eacute;rouleraient normalement
-    au cours du processus de traitement d'une requ&ecirc;te -- par exemple un
-    traitement effectu&eacute; par <module>mod_proxy</module>, ou
-    <module>mod_rewrite</module> --
-    ne seront pas effectu&eacute;es.  Mais c'est justement l'int&eacute;r&ecirc;t
-    de la mise en cache pr&eacute;alable du contenu.</p>
-
-    <p>Si l'URL ne se trouve pas dans le cache, <module>mod_cache</module>
-    va ajouter un <a href="filter.html">filtre</a> au traitement de la requ&ecirc;te.
-    Une fois le contenu localis&eacute; par httpd selon la conception courante, le
-    filtre sera ex&eacute;cut&eacute; en m&ecirc;me temps que le contenu sera servi.
-    S'il est d&eacute;termin&eacute; que le contenu peut &ecirc;tre mis en cache,
-    il sera sauvegard&eacute; dans le cache pour une utilisation future.</p>
-
-    <p>Si l'URL se trouve dans le cache, mais est arriv&eacute;e &agrave; expiration,
-    le filtre est quand-m&ecirc;me ajout&eacute;, mais <module>mod_cache</module> va cr&eacute;er
-    une requ&ecirc;te conditionnelle en arri&egrave;re-plan, pour d&eacute;terminer si la version
-    du cache est encore &agrave; jour. Si la version du cache est encore &agrave; jour, ses
-    meta-informations seront mises &agrave; jour et la requ&ecirc;te sera servie &agrave; partir du
-    cache. Si la version du contenu n'est plus &agrave; jour, elle sera supprim&eacute;e et le
-    filtre va sauvegarder le contenu mis &agrave; jour dans le cache
-    au moment o&ugrave; il sera servi.</p>
+    <p>Le module <module>mod_cache</module> permet de tirer avantage du
+    mécanisme de mise en cache en ligne faisant partie
+    intégrante du protocole HTTP, et décrit dans la <a
+    href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html">section
+    13 de la RFC2616</a>.</p>
+
+    <p>A la différence d'un cache simple clé/valeur à deux états où le
+    contenu est supprimé lorsqu'il est périmé, un cache HTTP comporte un
+    mécanisme permettant de conserver temporairement un contenu périmé,
+    de demander au serveur original si ce contenu périmé a été modifié,
+    et dans le cas contraire de le rendre à nouveau valide.</p>
+
+    <p>Une entrée d'un cache HTTP peut se présenter sous un de ces trois
+    états :</p>
+
+    <dl>
+    <dt>Frais</dt>
+    <dd>
+        Si un contenu est suffisamment récent (plus jeune que sa
+       <strong>durée de fraîcheur</strong>), il est considéré comme
+       <strong>frais</strong>. Un cache HTTP peut servir un contenu
+       frais sans avoir à demander quoi que ce soit au serveur
+       d'origine.
+    </dd>
+    <dt>Périmé</dt>
+    <dd>
+        <p>Si le contenu est trop ancien (plus vieux que sa
+       <strong>durée de fraîcheur</strong>), il est considéré comme
+       <strong>périmé</strong>. Un cache HTTP doit contacter le serveur
+       original pour vérifier si le contenu, même s'il est périmé, est
+       encore à jour avant de le servir au client. Soit le serveur
+       original va répondre en envoyant un contenu de remplacement si
+       le contenu périmé n'est plus à jour, soit dans le cas idéal il
+       renverra un code pour signaler au cache que le contenu est
+       encore à jour, et qu'il est inutile de le générer ou de
+       l'envoyer à nouveau. Le contenu repasse à l'état "frais" et le
+       cycle continue.</p>
+
+        <p>Le protocole HTTP permet au cache de servir des données
+       périmées dans certaines circonstances, comme lorsqu'une
+       tentative de rafraîchir une entrée depuis un serveur original
+       se solde par un échec avec un code d'erreur 5xx, ou lorsqu'une
+       autre requête est déjà en train d'essayer de rafraîchir la même
+       entrée. Dans ces cas, un en-tête <code>Warning</code> est ajouté
+       à la réponse.</p>
+    </dd>
+    <dt>Non Existent</dt>
+    <dd>
+        Si le cache est plein, il se réserve la possibilité de supprimer
+       des entrées pour faire de la place. Une entrée peut être
+       supprimée à tout moment, qu'elle soit fraîche ou périmée.
+       L'outil <a href="programs/htcacheclean.html">htcacheclean</a>
+       peut être utilisé à la demande, ou lancé en tant que démon afin
+       de conserver la taille du cache ou le nombre d'inodes en deçà de
+       valeurs spécifiées. Cet outil essaie cependant de
+       supprimer les entrées périmées avant les entrées fraîches.
+    </dd>
+    </dl>
+
+    <p>Le fonctionnement détaillé d'un cache HTTP est décrit dans la <a
+    href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html">Section
+    13 de la RFC2616</a>.</p>
 
     <section>
-      <title>Am&eacute;lioration du taux de pr&eacute;sence dans le cache</title>
-
-      <p>Lors de la mise en cache de contenu g&eacute;n&eacute;r&eacute; localement, le
-      positionnement de la directive
-      <directive module="core">UseCanonicalName</directive> &agrave;
-      <code>On</code> peut am&eacute;liorer de mani&egrave;re spectaculaire le taux de
-      pr&eacute;sence dans le cache. Ceci est du au fait que le nom d'h&ocirc;te de l'h&ocirc;te
-      virtuel qui sert le contenu constitue une partie de la cl&eacute; de cache.
-      Avec <directive module="core">UseCanonicalName</directive> positionn&eacute;e
-      &agrave; <code>On</code>,
-      les h&ocirc;tes virtuels poss&eacute;dant plusieurs noms de serveur ou alias ne
-      g&eacute;n&eacute;reront pas d'entit&eacute;s de cache diff&eacute;rentes, et le contenu sera mis en
-      cache en faisant r&eacute;f&eacute;rence au nom d'h&ocirc;te canonique.</p>
-
-      <p>Les documents mis en cache ne seront servis qu'en r&eacute;ponse &agrave; des
-      requ&ecirc;tes de type URL, car la mise en cache est effectu&eacute;e lors de la phase
-      de traduction de l'URL en nom de fichier.
-      En g&eacute;n&eacute;ral, cela n'a que peu d'effet, &agrave; moins que vous n'utilisiez les
-      <a href="howto/ssi.html">Inclusions C&ocirc;t&eacute; Serveur (SSI)</a>;</p>
+      <title>Interaction avec le serveur</title>
 
-      <example>
-&lt;!-- L'inclusion suivante peut &ecirc;tre mise en cache --&gt;<br />
-&lt;!--#include virtual="/footer.html" --&gt;<br />
-<br />
-&lt;!-- L'inclusion suivante ne peut pas &ecirc;tre mise en cache --&gt;<br />
-&lt;!--#include file="/path/to/footer.html" --&gt; <br />
-      </example>
+      <p>Le module <module>mod_cache</module> interagit avec le serveur
+      à deux niveaux possibles en fonction de la directive <directive
+      module="mod_cache">CacheQuickHandler</directive> :
+      </p>
 
-      <p>Si vous utilisez les SSI, et voulez b&eacute;n&eacute;ficier de la vitesse de
-      service depuis le cache, vous devez utiliser des inclusions de type
-      <code>virtual</code>.</p>
+      <dl>
+        <dt>Phase du gestionnaire rapide</dt>
+        <dd>
+          <p>Cette phase se déroule très tôt au cours du traitement de
+         la requête, juste après l'interprétation de cette dernière. Si
+         le contenu se trouve dans le cache, il est servi immédiatement
+         et pratiquement tout le reste du traitement de la requête est
+         court-circuité.</p>
+
+              <p>Dans ce scénario, le cache se comporte comme s'il avait
+             été "boulonné" à l'entrée du serveur.</p>
+              
+              <p>Ce mode possède les meilleures performances car la
+             majorité des traitements au niveau du serveur sont
+             court-circuités. Cependant, il court-circuite aussi les
+             phases d'authentification et d'autorisation du traitement
+             au niveau du serveur, et il doit donc être utilisé avec
+             prudence lorsque que ces phases sont importantes.</p>
+
+             <p>Les requêtes contenant un en-tête "Authorization"
+             header (par exemple dans le cas de l'authentification HTTP
+             basique) ne peuvent ni être mises en cache, ni servies
+             depuis le cache lorsque <module>mod_cache</module>
+             s'exécute dans cette phase.</p>
+          </dd>
+          <dt>Phase du gestionnaire normal</dt>
+          <dd>
+              <p>Cette phase se déroule très tard au cours du traitement
+             de la requête, en fait après toutes les phases de ce
+             traitement.</p>
+
+              <p>Dans ce scénario, le cache se comporte comme s'il avait
+             été "boulonné" à la sortie du serveur.</p>
+
+              <p>Ce mode offre la plus grande souplesse, car il permet
+             de faire intervenir la mise en cache en un point
+             précisément spécifié de la chaîne de filtrage, et le
+             contenu issu du cache peut être filtré ou personnalisé
+             avant d'être servi au client.</p>
+          </dd>
+        </dl>
+
+        <p>Si l'URL ne se trouve pas dans le cache,
+       <module>mod_cache</module> ajoutera un <a
+       href="filter.html">filtre</a> à la chaîne de filtrage afin
+       d'enregistrer la réponse dans le cache, puis passera la main
+       pour permettre le déroulement normal de la suite du traitement
+       de la requête. Si la mise en cache du contenu est autorisée, il
+       sera enregistré dans le cache pour pouvoir être servi à nouveau
+       ; dans le cas contraire, le contenu sera ignoré.</p>
+
+        <p>Si le contenu trouvé dans le cache est périmé, le module
+       <module>mod_cache</module> convertit la requête en
+       <strong>requête conditionnelle</strong>. Si le serveur original
+       renvoie une réponse normale, elle est enregistrée dans le cache
+       en lieu et place du contenu périmé. Si le serveur original
+       renvoie une réponse "304 Not Modified", le contenu repasse à
+       l'état "frais" et est servi par le filtre au lieu d'être
+       sauvegardé.</p>
     </section>
 
     <section>
-      <title>P&eacute;riodes d'expiration</title>
+      <title>Amélioration du taux de présence dans le cache</title>
+
+      <p>Lorsqu'un serveur virtuel est connu sous la forme d'un des
+      nombreux alias du serveur, la définition de la directive
+      <directive module="core">UseCanonicalName</directive> à
+      <code>On</code> peut augmenter de manière significative le nombre
+      de correspondances positives dans le cache. Ceci est du au fait
+      que la clé du cache contient le nom d'hôte du serveur virtuel.     
+      Avec <directive module="core">UseCanonicalName</directive> positionnée
+      à <code>On</code>,
+      les hôtes virtuels possédant plusieurs noms de serveur ou alias ne
+      généreront pas d'entités de cache différentes, et le contenu sera mis en
+      cache en faisant référence au nom d'hôte canonique.</p>
 
-      <p>La p&eacute;riode d'expiration par d&eacute;faut pour les entit&eacute;s du cache est
-      d'une heure; elle peut cependant &ecirc;tre facilement modifi&eacute;e &agrave; l'aide de
+    </section>
+
+    <section>
+      <title>Durée de fraîcheur</title>
+
+       <p>Un contenu bien formé destiné à être mis en cache doit déclarer
+       explicitement une durée de fraîcheur via les champs
+       <code>max-age</code> ou <code>s-maxage</code> de l'en-tête
+       <code>Cache-Control</code>, ou en incluant un en-tête
+       <code>Expires</code>.</p>
+      
+      <p>De plus, un client peut passer outre la durée de fraîcheur
+      définie pour le serveur original en ajoutant son propre en-tête
+      <code>Cache-Control</code> à la requête. Dans ce cas, c'est la
+      durée de fraîcheur la plus basse entre la requête et la réponse
+      qui l'emporte.</p>
+
+      <p>Lorsque cette durée de fraîcheur est absente de la requête ou
+      de la réponse, une durée de fraîcheur par défaut s'applique. La
+      durée de fraîcheur par défaut des entrées du cache est d'une heure
+      ; elle peut cependant être facilement modifiée à l'aide de
       la directive <directive
-      module="mod_cache">CacheDefaultExpire</directive>. Cette valeur par
-      d&eacute;faut n'est utilis&eacute;e que lorsque la source originale du contenu ne
-      pr&eacute;cise pas de p&eacute;riode d'expiration ou d'heure de derni&egrave;re
-      modification.</p>
-
-      <p>Si une r&eacute;ponse ne contient pas d'en-t&ecirc;te <code>Expires</code> mais
-      inclut un en-t&ecirc;te <code>Last-Modified</code>, <module>mod_cache</module>
-      peut d&eacute;duire une p&eacute;riode d'expiration en se basant sur la valeur de la
-      directive <directive
+      module="mod_cache">CacheDefaultExpire</directive>.</p>
+
+      <p>Si une réponse ne contient pas d'en-tête <code>Expires</code> mais
+      inclut un en-tête <code>Last-Modified</code>, <module>mod_cache</module>
+      peut déduire une durée de fraîcheur en se basant sur une
+      heuristique, qui peut être contrôlée via la directive <directive
       module="mod_cache">CacheLastModifiedFactor</directive>.</p>
 
-      <p>La p&eacute;riode d'expiration des contenus locaux peut &ecirc;tre ajust&eacute;e finement
-      en utilisant le module <module>mod_expires</module>.</p>
+      <p>Pour les contenus locaux, ou les contenus distants qui ne
+      spécifient pas leur propre en-tête <code>Expires</code>,
+      <module>mod_expires</module> permet de régler finement la durée de
+      fraîcheur via les paramètres <code>max-age</code> et
+      <code>Expires</code>.</p>
 
-      <p>On peut aussi contr&ocirc;ler la p&eacute;riode d'expiration maximale en utilisant
+      <p>On peut aussi contrôler la durée de fraîcheur maximale en utilisant
       la directive <directive module="mod_cache">CacheMaxExpire</directive>.</p>
 
     </section>
 
     <section>
-      <title>Guide succinct des requ&ecirc;tes conditionnelles</title>
-
-      <p>Lorsqu'un contenu est arriv&eacute; &agrave; expiration dans le cache et fait
-      l'objet d'une nouvelle demande d'acc&egrave;s, plut&ocirc;t que traiter directement
-      la requ&ecirc;te originale, httpd pr&eacute;f&egrave;re utiliser une
-      requ&ecirc;te conditionnelle.</p>
-
-      <p>HTTP propose toute une panoplie d'en-t&ecirc;tes qui permettent &agrave; un client,
-      ou au cache de distinguer les diff&eacute;rentes versions d'un m&ecirc;me contenu. Par
-      exemple, si une ressource a &eacute;t&eacute; servie avec un en-t&ecirc;te "Etag:", il est
-      possible de cr&eacute;er une requ&ecirc;te conditionnelle contenant un en-t&ecirc;te
-      "If-None-Match:". Si une ressource a &eacute;t&eacute; servie avec un en-t&ecirc;te
-      "Last-Modified:", il est possible de cr&eacute;er une requ&ecirc;te conditionnelle
-      contenant un en-t&ecirc;te "If-Modified-Since:", etc....</p>
-
-      <p>Lorsqu'une telle requ&ecirc;te conditionnelle est cr&eacute;&eacute;e, la reponse diff&egrave;re
-      selon que le contenu satisfait ou non aux conditions. Si une requ&ecirc;te est
-      cr&eacute;&eacute;e avec un en-t&ecirc;te "If-Modified-Since:", et le contenu n'a pas &eacute;t&eacute;
-      modifi&eacute; depuis le moment indiqu&eacute; dans la requ&ecirc;te, alors un laconique
-      "304 Not Modified" est retourn&eacute;.</p>
-
-      <p>Si le contenu a &eacute;t&eacute; modifi&eacute;, il est servi comme si la requ&ecirc;te n'avait
-      pas &eacute;t&eacute; conditionnelle &agrave; l'origine.</p>
-
-      <p>Les b&eacute;n&eacute;fices des requ&ecirc;tes conditionnelles pour ce qui concerne la
-      mise en cache sont de deux sortes. Premi&egrave;rement, quand une telle requ&ecirc;te
-      est envoy&eacute;e au processus en arri&egrave;re-plan, il sera ais&eacute; de d&eacute;terminer
-      si le contenu que devra servir le processus en arri&egrave;re-plan correspond
-      au contenu stock&eacute; dans le cache, sans &ecirc;tre oblig&eacute; de transmettre la
-      totalit&eacute; de la ressource.</p>
-
-      <p>Deuxi&egrave;mement, les requ&ecirc;tes conditionnelles sont en g&eacute;n&eacute;ral moins
-      co&ucirc;teuses en ressources pour le processus en arri&egrave;re-plan.
-      Pour ce qui est des fichiers
-      statiques, l'action type est un appel &agrave; <code>stat()</code> ou un appel
-      syst&egrave;me similaire, pour d&eacute;terminer si la taille du fichier ou sa date de
-      modification ont chang&eacute;. Ainsi, m&ecirc;me si httpd met en cache le contenu
-      local, un contenu arriv&eacute; &agrave; expiration pourra &ecirc;tre servi plus rapidement
-      depuis le cache s'il n'a pas &eacute;t&eacute; modifi&eacute;, parce que la lecture depuis le
-      cache est plus rapide que la lecture depuis le processus en arri&egrave;re-plan
-      (&agrave; comparer &agrave; la diff&eacute;rence de vitesse entre la lecture depuis un cache en
-      m&eacute;moire avec <module>mod_cache_disk</module> et la lecture depuis un disque).</p>
+      <title>Guide succinct des requêtes conditionnelles</title>
+
+     <p>Lorsqu'un contenu du cache est périmé, httpd modifie la requête
+     pour en faire une requête conditionnelle</p>
+
+      <p>Lorsque la réponse originale du cache contient un en-tête
+      <code>ETag</code>, <module>mod_cache</module> ajoute un en-tête
+      <code>If-None-Match</code> à la requête envoyée au serveur
+      d'origine. Lorsque la réponse originale du cache contient un en-tête
+      <code>Last-Modified</code>, <module>mod_cache</module> ajoute un en-tête
+      <code>If-Modified-Since</code> à la requête envoyée au serveur
+      d'origine. Dans ces deux cas, la requête devient une requête
+      <strong>conditionnelle</strong>.</p>
+
+      <p>Lorsqu'un serveur d'origine reçoit une requête conditionnelle,
+      il vérifie si le paramètre Etag ou Last-Modified a été modifié en
+      fonction des paramètres de la requête. Si ce n'est pas le cas, il
+      répondra avec le message lapidaire "304 Not Modified". Ceci
+      informe le cache que le contenu est périmé mais encore à jour, et
+      peut être utilisé tel quel pour les prochaines requêtes jusqu'à ce
+      qu'il atteigne à nouveau sa date de péremption.</p>
+
+      <p>Si le contenu a été modifié, il est servi comme s'il s'agissait
+      d'une requête normale et non conditionnelle.</p>
+
+      <p>Les requêtes conditionnelles offrent deux avantages. D'une
+      part, il est facile de déterminer si le contenu du serveur
+      d'origine correspond à celui situé
+      dans le cache, et ainsi d'économiser la consommation de ressources
+      nécessaire au transfert du contenu dans son ensemble.</p>
+
+      <p>D'autre part, un serveur d'origine bien conçu sera configuré de
+      telle manière que les requêtes conditionnelles nécessitent pour
+      leur production bien moins de ressources qu'une réponse complète.
+      Dans le cas des fichiers statiques, il suffit en général d'un
+      appel système de type <code>stat()</code> ou similaire pour
+      déterminer si la taille ou la date de modification du fichier a
+      été modifiée. Ainsi, même un contenu local pourra être servi plus
+      rapidement depuis le cache s'il n'a pas été modifié.</p>
+      
+      <p>Il serait souhaitable que tous les serveurs d'origine
+      supportent les requêtes conditionnelles, car dans le cas
+      contraire, ils répondent comme s'il s'agissait d'une requête
+      normale, et le cache répond comme si le contenu avait été
+      modifié et enregistre ce dernier. Le cache se comporte alors
+      comme un simple cache à deux état, où le contenu est servi s'il
+      est à jour, ou supprimé dans le cas contraire.</p>
     </section>
 
     <section>
       <title>Que peut-on mettre en cache ?</title>
 
-      <p>Comme mentionn&eacute; plus haut, les deux styles de mise en
-      cache de httpd
-      fonctionnent diff&eacute;remment; la mise en cache de
-      <module>mod_file_cache</module> conserve les contenus des fichiers
-      tels qu'ils &eacute;taient au d&eacute;marrage de httpd. Quand une requ&ecirc;te pour un
-      fichier mis en cache par ce module est envoy&eacute;e, elle est intercept&eacute;e
-      et le fichier mis en cache est servi.</p>
-
-      <p>La mise en cache de <module>mod_cache</module>, quant &agrave; elle, est
-      plus complexe. Lors du traitement d'une requ&ecirc;te, le module de mise en
-      cache d&eacute;terminera si le contenu peut &ecirc;tre mis en cache, s'il ne l'a
-      pas d&eacute;j&agrave; &eacute;t&eacute; auparavant. Les conditions qui permettent de d&eacute;terminer
-      la possibilit&eacute; de mise en cache d'une r&eacute;ponse sont :</p>
+      <p>La liste complète des conditions nécessaires pour qu'une
+      réponse puisse être enregistrée dans un cache HTTP est fournie
+      dans la <a
+      href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html#sec13.4">section
+      13.4 Response Cacheability de la RFC2616</a>, et peut se résumer
+      ainsi :</p>
 
       <ol>
-        <li>La mise en cache doit &ecirc;tre activ&eacute;e pour cette URL. Voir les
+        <li>La mise en cache doit être activée pour cette URL. Voir les
        directives <directive
         module="mod_cache">CacheEnable</directive> et <directive
         module="mod_cache">CacheDisable</directive>.</li>
 
-        <li>La reponse doit avoir un code de statut HTTP de 200, 203, 300, 301
-       ou 410.</li>
-
-        <li>La requ&ecirc;te doit &ecirc;tre de type HTTP GET.</li>
+        <li>Si la reponse possède un code de statut HTTP autre que 200, 203, 300, 301
+       ou 410, elle doit aussi comporter un en-tête "Expires" ou
+       "Cache-Control".</li>
 
-        <li>Si la requ&ecirc;te contient un en-t&ecirc;te "Authorization:", la r&eacute;ponse ne
-       sera pas mise en cache.</li>
+        <li>La requête doit être de type HTTP GET.</li>
 
-        <li>Si la r&eacute;ponse contient un en-t&ecirc;te "Authorization:", elle doit aussi
+        <li>Si la réponse contient un en-tête "Authorization:", elle doit aussi
        contenir une option "s-maxage", "must-revalidate" ou "public"
-       dans l'en-t&ecirc;te "Cache-Control:".</li>
-
-        <li>Si l'URL contient une cha&icirc;ne de requ&ecirc;te
-       (provenant par exemple d'une m&eacute;thode GET de formulaire HTML), elle ne
-       sera pas mise en cache, &agrave; moins que la r&eacute;ponse ne
-       sp&eacute;cifie explicitement un d&eacute;lai d'expiration via un
-       en-t&ecirc;te "Expires:" ou une directive max-age ou s-maxage de
-       l'en-t&ecirc;te "Cache-Control:" comme indiqu&eacute; dans les
+       dans l'en-tête "Cache-Control:".</li>
+
+        <li>Si l'URL contient une chaîne de requête
+       (provenant par exemple d'une méthode GET de formulaire HTML), elle ne
+       sera pas mise en cache, à moins que la réponse ne
+       spécifie explicitement un délai d'expiration via un
+       en-tête "Expires:" ou une directive max-age ou s-maxage de
+       l'en-tête "Cache-Control:" comme indiqué dans les
        sections 13.2.1. et 13.9 de la RFC2616.</li>
 
-        <li>Si la r&eacute;ponse a un statut de 200 (OK), elle doit aussi contenir
-       au moins un des en-t&ecirc;tes "Etag", "Last-Modified" ou
+        <li>Si la réponse a un statut de 200 (OK), elle doit aussi contenir
+       au moins un des en-têtes "Etag", "Last-Modified" ou
         "Expires", ou une directive max-age ou s-maxage de
-       l'en-t&ecirc;te "Cache-Control:", &agrave; moins que la directive
+       l'en-tête "Cache-Control:", à moins que la directive
         <directive module="mod_cache">CacheIgnoreNoLastMod</directive>
-        ne pr&eacute;cise d'autres contraintes.</li>
+        ne précise d'autres contraintes.</li>
 
-        <li>Si la r&eacute;ponse contient l'option "private" dans un en-t&ecirc;te
-       "Cache-Control:", elle ne sera pas mise en cache &agrave; moins que la
+        <li>Si la réponse contient l'option "private" dans un en-tête
+       "Cache-Control:", elle ne sera pas mise en cache à moins que la
        directive
         <directive module="mod_cache">CacheStorePrivate</directive>
-       ne pr&eacute;cise d'autres contraintes.</li>
+       ne précise d'autres contraintes.</li>
 
-        <li>De m&ecirc;me, si la r&eacute;ponse contient l'option "no-store" dans un en-t&ecirc;te
-        "Cache-Control:", elle ne sera pas mise en cache &agrave; moins que la
+        <li>De même, si la réponse contient l'option "no-store" dans un en-tête
+        "Cache-Control:", elle ne sera pas mise en cache à moins que la
        directive
         <directive module="mod_cache">CacheStoreNoStore</directive>
-       n'ait &eacute;t&eacute; utilis&eacute;e.</li>
+       n'ait été utilisée.</li>
 
-        <li>Une r&eacute;ponse ne sera pas mise en cache si elle comporte un en-t&ecirc;te
-       "Vary:" contenant le caract&egrave;re "*" qui correspond &agrave; toute
-       cha&icirc;ne de caract&egrave;res.</li>
+        <li>Une réponse ne sera pas mise en cache si elle comporte un en-tête
+       "Vary:" contenant le caractère "*" qui correspond à toute
+       chaîne de caractères.</li>
       </ol>
     </section>
 
     <section>
-      <title>Qu'est ce qui ne doit pas &ecirc;tre mis en cache ?</title>
-
-      <p>En bref, tout contenu qui varie beaucoup avec le temps, ou en fonction
-      de particularit&eacute;s de la requ&ecirc;te qui ne sont pas couvertes par la
-      n&eacute;gociation HTTP, ne doit pas &ecirc;tre mis en cache.</p>
-
-      <p>Un contenu dynamique qui varie en fonction de l'adresse IP du
-      demandeur, ou est modifi&eacute; toutes les 5 minutes, ne devra en g&eacute;n&eacute;ral
-      pas &ecirc;tre mis en cache.</p>
+      <title>Qu'est ce qui ne doit pas être mis en cache ?</title>
+
+      <p>Le client qui crée la requête ou le serveur d'origine qui
+      génère la réponse doit être à même de déterminer si le contenu
+      doit pouvoir être mis en cache ou non en définissant correctement
+      l'en-tête <code>Cache-Control</code>, et
+      <module>mod_cache</module> sera alors en mesure de satisfaire les
+      souhaits du client ou du serveur de manière appropriée.
+      </p>
 
-      <p>Si par contre le contenu servi diff&egrave;re en fonction de la valeur de
-      divers en-t&ecirc;tes HTTP, il se peut que l'on puisse le mettre en cache
-      intelligemment en utilisant un en-t&ecirc;te "Vary".</p>
+      <p>Les contenus qui varient au cours du temps, ou en fonction de
+      particularités de la requête non prises en compte par la
+      négociation HTTP ne doivent pas être mis en cache. Ce type de
+      contenu doit se déclarer lui-même "à ne pas mettre en cache" via
+      l'en-tête <code>Cache-Control</code>.</p>
+      
+      <p>Si le contenu change souvent, suite par exemple à une durée de
+      fraîcheur de l'ordre de la minute ou de la seconde, il peut tout
+      de même être mis en cache, mais il est alors fortement souhaitable
+      que le serveur d'origine supporte correctement les
+      <strong>requêtes conditionnelles</strong> afin que des réponses
+      complètes ne soient pas systématiquement générées.</p>
+
+      <p>Un contenu qui varie en fonction d'en-têtes de requête fournis
+      par le client peut être mis en cache, sous réserve d'une
+      utilisation appropriée de l'en-tête de réponse <code>Vary</code>.</p>
     </section>
 
     <section>
-      <title>Contenu variable et/ou n&eacute;goci&eacute;</title>
-
-      <p>Si <module>mod_cache</module> re&ccedil;oit une r&eacute;ponse contenant un en-t&ecirc;te
-      "Vary", lorsqu'un contenu a &eacute;t&eacute; demand&eacute; par un processus d'arri&egrave;re-plan,
-      il va s'efforcer de la traiter intelligemment. Si possible,
-      <module>mod_cache</module> va d&eacute;tecter les en-t&ecirc;tes attribu&eacute;s dans la
-      r&eacute;ponse "Vary" &agrave; l'occasion des futures demandes, et servir une r&eacute;ponse
-      correcte &agrave; partir du cache.</p>
-
-      <p>Si par exemple, une r&eacute;ponse est re&ccedil;ue avec l'en-t&ecirc;te Vary suivant,</p>
+      <title>Contenu variable et/ou négocié</title>
+
+      <p>Lorsque le serveur d'origine est configuré pour servir des
+      contenus différents en fonction de la valeur de certains en-têtes
+      de la requête, par exemple pour servir une ressource en plusieurs
+      langages à partir d'une seule URL, le mécanisme de mise en cache
+      d'HTTP permet de mettre en cache plusieurs variantes de la même
+      page à partir d'une seule URL.</p>
+      
+      <p>Pour y parvenir, le serveur d'origine ajoute un en-tête
+      <code>Vary</code> pour indiquer quels en-têtes doivent être pris
+      en compte par un cache pour déterminer si deux variantes sont
+      différentes l'une de l'autre.</p>
+
+      <p>Si par exemple, une réponse est reçue avec l'en-tête Vary suivant,</p>
 
       <example>
 Vary: negotiate,accept-language,accept-charset
       </example>
 
       <p><module>mod_cache</module> ne servira aux demandeurs que le contenu
-      mis en cache qui correspond au contenu des en-t&ecirc;tes accept-language et
-      accept-charset de la requ&ecirc;te originale.</p>
+      mis en cache qui correspond au contenu des en-têtes accept-language et
+      accept-charset de la requête originale.</p>
+
+      <p>Plusieurs variantes d'un contenu peuvent être mises en cache
+      simultanément ; <module>mod_cache</module> utilise l'en-tête
+      <code>Vary</code> et les valeurs correspondantes des en-têtes de
+      la requête spécifiés dans ce dernier pour
+      déterminer quelle variante doit être servie au client.</p>
+          
     </section>
 
   </section>
 
-  <section id="security">
-    <title>Consid&eacute;rations sur la s&eacute;curit&eacute;</title>
+  <section id="examples">
 
-    <section>
-      <title>Autorisation et contr&ocirc;le d'acc&egrave;s</title>
+    <title>Exemples de configuration du cache</title>
 
-      <p>Utiliser <module>mod_cache</module> revient sensiblement &agrave; la m&ecirc;me
-      chose qu'avoir un mandataire inverse int&eacute;gr&eacute; (reverse-proxy). Les requ&ecirc;tes
-      seront servies par le module de mise en cache sauf si ce dernier
-      d&eacute;termine qu'un processus d'arri&egrave;re-plan doit &ecirc;tre appel&eacute;. La mise en
-      cache de ressources locales modifie consid&eacute;rablement le mod&egrave;le de
-      s&eacute;curit&eacute; de httpd.</p>
-
-      <p>Comme le parcours de la hi&eacute;rarchie d'un syst&egrave;me de fichiers pour
-      examiner le contenu d'&eacute;ventuels fichiers
-      <code>.htaccess</code> serait une op&eacute;ration tr&egrave;s co&ucirc;teuse en ressources,
-      annulant partiellement de ce fait l'int&eacute;r&ecirc;t de la mise en cache
-      (acc&eacute;l&eacute;rer le traitement des requ&ecirc;tes),
-      <module>mod_cache</module> ne se pr&eacute;occupe pas de savoir s'il a
-      l'autorisation de servir une entit&eacute; mise en cache. En d'autres termes,
-      si <module>mod_cache</module> a mis en cache un certain contenu, ce
-      dernier sera servi &agrave; partir du cache tant qu'il ne sera pas arriv&eacute; &agrave;
-      expiration.</p>
+    <related>
+      <modulelist>
+        <module>mod_cache</module>
+        <module>mod_cache_disk</module>
+        <module>mod_cache_socache</module>
+        <module>mod_socache_memcache</module>
+      </modulelist>
+      <directivelist>
+        <directive module="mod_cache">CacheEnable</directive>
+        <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_socache">CacheSocache</directive>
+      </directivelist>
+    </related>
+
+    <section id="disk">
+      <title>Mise en cache sur disque</title>
+
+      <p>Le module <module>mod_cache</module> s'appuie sur des
+      implémentations de stockage sous-jacentes spécifiques pour gérer
+      le cache ; à ce titre, <module>mod_cache_disk</module> fournit le
+      support de la mise en cache sur disque.</p>
+
+      <p>En général, le module se configure comme suit :</p>
+
+      <highlight language="config">
+CacheRoot   "/var/cache/apache/"
+CacheEnable disk /
+CacheDirLevels 2
+CacheDirLength 1
+    </highlight>
+
+    <p>Il est important de savoir que, les fichiers mis en cache étant stockés
+    localement, la mise en cache par l'intermédiaire du système d'exploitation
+    sera en général aussi appliquée à leurs accès. Si bien que même si les
+    fichiers sont stockés sur disque, s'il font l'objet d'accès fréquents,
+    il est probable que le système d'exploitation s'appliquera à ce qu'ils
+    soient servis à partir de la mémoire.</p>
 
-      <p>Si par exemple, votre configuration autorise l'acc&egrave;s &agrave; une ressource
-      en fonction de l'adresse IP, vous devez vous assurer que ce contenu n'est
-      pas mis en cache. Ceci est possible en utilisant la directive
-      <directive module="mod_cache">CacheDisable</directive>, ou le module
-      <module>mod_expires</module>. Livr&eacute; &agrave; lui-m&ecirc;me,
-      <module>mod_cache</module> - pratiquement comme un mandataire inverse -
-      mettrait en cache le contenu lors de son service, et le servirait ensuite
-      &agrave; tout client, vers n'importe quelle adresse IP.</p>
     </section>
 
     <section>
-      <title>Piratages locaux</title>
+      <title>Comprendre le stockage dans le cache</title>
 
-      <p>Etant donn&eacute; que les requ&ecirc;tes des utilisateurs finaux peuvent &ecirc;tre
-      servies depuis le cache, ce dernier est une cible potentielle pour ceux
-      qui veulent d&eacute;figurer un contenu ou interf&eacute;rer avec lui. Il est important
-      de garder &agrave; l'esprit que l'utilisateur sous lequel tourne
-      httpd doit
-      toujours avoir l'acc&egrave;s en &eacute;criture dans le cache. Ceci est en contraste
-      total avec la recommandation usuelle d'interdire &agrave; l'utilisateur sous
-      lequel tourne Apache
-      l'acc&egrave;s en &eacute;criture &agrave; tout contenu.</p>
+      <p>Pour stocker des entités dans le cache,
+      le module <module>mod_cache_disk</module> crée une empreinte (hash) de 22
+      caractères de l'URL qui a fait l'objet d'une requête. Cette empreinte
+      comprend le nom d'hôte, le protocole, le port, le chemin et tout argument
+      de type CGI associé à l'URL, ainsi que les éléments
+      spécifiés dans l'en-tête Vary afin d'être sur que plusieurs URLs
+      n'interfèrent pas entre elles.</p>
+
+      <p>Chaque position de l'empreinte peut contenir un caractère
+      choisi parmi 64 caractères différents, il y a donc
+      64^22 possibilités pour une empreinte. Par exemple, une URL peut posséder
+      l'empreinte <code>xyTGxSMO2b68mBCykqkp1w</code>. Cette empreinte est
+      utilisée pour préfixer les noms de fichiers spécifiques à cette URL à
+      l'intérieur du cache; cependant, elle est tout d'abord placée dans les
+      répertoires du cache selon les directives
+      <directive module="mod_cache_disk">CacheDirLevels</directive> et
+      <directive module="mod_cache_disk">CacheDirLength</directive>.</p>
 
-      <p>Si l'utilisateur sous lequel tourne Apache est compromis,
-      par exemple &agrave; cause d'une
-      faille de s&eacute;curit&eacute; dans un processus CGI, il est possible que le cache
-      fasse l'objet d'une attaque. Il est relativement ais&eacute; d'ins&eacute;rer ou de
-      modifier une entit&eacute; dans le cache en utilisant le module
-      <module>mod_cache_disk</module>.</p>
+      <p>La directive
+      <directive module="mod_cache_disk">CacheDirLevels</directive>
+      définit le nombre de niveaux de sous-répertoires, et
+      <directive module="mod_cache_disk">CacheDirLength</directive>
+      le nombre de caractères composant le nom des sous-répertoires. Dans
+      l'exemple donné plus haut, l'empreinte se trouvera à :
+      <code>/var/cache/apache/x/y/TGxSMO2b68mBCykqkp1w</code>.</p>
 
-      <p>Cela repr&eacute;sente un risque relativement &eacute;l&eacute;v&eacute; par rapport aux autres
-      types d'attaques qu'il est possible de mener sous l'utilisateur apache.
-      Si vous utilisez <module>mod_cache_disk</module>, vous devez garder ceci
-      &agrave; l'esprit : effectuez toujours les mises &agrave; jour de
-      httpdquand des
-      correctifs de s&eacute;curit&eacute; sont annonc&eacute;s et ex&eacute;cutez les processus CGI sous
-      un utilisateur autre qu'apache en utilisant
-      <a href="suexec.html">suEXEC</a> dans la mesure du possible.</p>
+      <p>Cette technique a pour but principal de réduire le nombre de
+      sous-répertoires ou de fichiers contenus dans un répertoire particulier,
+      car le fonctionnement de la plupart des systèmes de fichiers est ralenti
+      quand ce nombre augmente. Avec la valeur "1" pour la directive
+      <directive module="mod_cache_disk">CacheDirLength</directive>,
+      il peut y avoir au plus 64 sous-répertoires à un niveau quelconque.
+      Avec la valeur "2", il peut y en avoir 64 * 64, etc...
+      A moins d'avoir une bonne raison pour ne pas le faire, l'utilisation de
+      la valeur "1" pour la directive
+      <directive module="mod_cache_disk">CacheDirLength</directive>
+      est recommandée.</p>
 
+      <p>Le paramétrage de la directive
+      <directive module="mod_cache_disk">CacheDirLevels</directive>
+      dépend du nombre de fichiers que vous pensez stocker dans le cache.
+      Avec une valeur de "2" comme dans l'exemple donné plus haut,
+      4096 sous-répertoires peuvent être créés au total. Avec 1 million de
+      fichiers dans le cache, cela équivaut à environ 245 URLs mises en cache
+      dans chaque répertoire.</p>
+
+      <p>Chaque URL nécessite au moins deux fichiers dans le cache. Ce sont en
+      général un fichier ".header", qui contient des meta-informations à propos
+      de l'URL, comme la date de son arrivée à expiration,
+      et un fichier ".data" qui est la copie exacte du contenu à servir.</p>
+
+      <p>Dans le cas d'un contenu négocié via l'en-tête "Vary", un répertoire
+      ".vary" sera créé pour l'URL en question. Ce répertoire contiendra de
+      multiples fichiers ".data" correspondant aux différents contenus
+      négociés.</p>
     </section>
 
     <section>
-      <title>Empoisonnement du cache (Cache Poisoning)</title>
+      <title>Maintenance du cache sur disque</title>
 
-      <p>Si vous utilisez httpd comme serveur mandataire avec mise en cache,
-      vous vous exposez aussi &agrave; un &eacute;ventuel "Empoisonnement du
-      cache" (Cache poisoning). L'empoisonnement du cache est un terme g&eacute;n&eacute;ral
-      pour d&eacute;signer les attaques au cours desquelles l'attaquant fait en sorte
-      que le serveur mandataire renvoie &agrave; un contenu incorrect (et souvent
-      ind&eacute;sirable) suite &agrave; en provenance du serveur d'arri&egrave;re-plan.
-      </p>
+      <p>Le module <module>mod_cache_disk</module> n'effectue aucune
+      régulation de l'espace disque utilisé par le cache, mais s'il
+      s'arrête en douceur en cas d'erreur disque et se comporte alors
+      comme si le cache n'avait jamais existé.</p>
 
-      <p>Par exemple, si les serveur DNS qu'utilise votre syst&egrave;me o&ugrave; tourne
-      httpd sont vuln&eacute;rables &agrave; l'empoisonnement du cache des DNS, un attaquant
-      pourra contr&ocirc;ler vers o&ugrave; httpd se connecte lorsqu'il demande un contenu
-      depuis le serveur d'origine.
-      Un autre exemple est constitu&eacute; par les attaques ainsi nomm&eacute;es
-      "Dissimulation de requ&ecirc;tes HTTP" (HTTP request-smuggling).</p>
+      <p>Par contre l'utilitaire
+      <a href="programs/htcacheclean.html">htcacheclean</a> fourni avec
+      httpd
+      vous permet de nettoyer le cache périodiquement.
+      Déterminer la fréquence à laquelle lancer <a
+      href="programs/htcacheclean.html">htcacheclean</a> et la taille souhaitée
+      pour le cache est une tâche relativement complexe et il vous faudra de
+      nombreux essais et erreurs pour arriver à sélectionner des valeurs
+      optimales.</p>
 
-      <p>Ce document n'est pas le bon endroit pour une discussion approfondie
-      &agrave; propos de la Dissimulation de requ&ecirc;tes HTTP (utilisez plut&ocirc;t votre
-      moteur de recherche favori); il est cependant important de savoir qu'il
-      est possible d'&eacute;laborer une s&eacute;rie de requ&ecirc;tes, et d'exploiter une
-      vuln&eacute;rabilit&eacute; d'un serveur web d'origine de telle fa&ccedil;on que l'attaquant
-      puisse contr&ocirc;ler enti&egrave;rement le contenu renvoy&eacute; par le mandataire.</p>
+      <p><a href="programs/htcacheclean.html">htcacheclean</a> opère selon deux
+      modes. Il peut s'exécuter comme démon résident, ou être lancé
+      périodiquement par cron. <a
+      href="programs/htcacheclean.html">htcacheclean</a> peut mettre une heure
+      ou plus pour traiter de très grands caches (plusieurs dizaines de
+      Gigaoctets) et si vous l'exécutez à partir de cron, il vous est
+      conseillé de déterminer la durée typique d'un traitement, afin d'éviter
+      d'exécuter plusieurs instances à la fois.</p>
+
+      <p>Il est aussi conseillé d'attribuer un niveau de priorité "nice"
+      approprié à htcacheclean de façon à ce qu'il n'effectue pas trop
+      d'accès disque pendant le fonctionnement du serveur.</p>
+
+      <p class="figure">
+      <img src="images/caching_fig1.gif" alt="" width="600"
+          height="406" /><br />
+      <a id="figure1" name="figure1"><dfn>Figure 1</dfn></a>: Croissance
+      typique du cache / séquence de nettoyage.</p>
+
+      <p>Comme <module>mod_cache_disk</module> ne tient pas compte de l'espace
+      utilisé dans le cache, vous devez vous assurer que
+      <a href="programs/htcacheclean.html">htcacheclean</a> est configuré de
+      façon à laisser suffisamment d'"espace de croissance"
+      à la suite d'un nettoyage.</p>
     </section>
+
+    <section id="memcache">
+      <title>Cache en mémoire</title>
+
+      <p>En utilisant le module <module>mod_cache_socache</module>,
+      <module>mod_cache</module> peut mettre en cache des données à partir de
+      diverses implémentations aussi nommées "fournisseurs". Par exemple, en
+      utilisant le module <module>mod_socache_memcache</module>, on peut
+      spécifier que c'est <a href="http://memcached.org">memcached</a> qui doit
+      être utilisé comme mécanisme de stockage sous-jacent.</p>
+
+      <p>Typiquement, le module sera configuré comme suit :</p>
+
+      <highlight language="config">
+CacheEnable socache /
+CacheSocache memcache:memcd.example.com:11211
+      </highlight>
+
+      <p>En outre, il est possible de spécifier plusieurs serveurs
+      <code>memcached</code> en les ajoutant à la fin de la ligne
+      <code>CacheSocache memcache:</code> et en les séparant par des virgules :</p>
+
+      <highlight language="config">
+CacheEnable socache /
+CacheSocache memcache:mem1.example.com:11211,mem2.example.com:11212
+      </highlight>
+
+      <p>Divers autres fournisseurs <module>mod_cache_socache</module> utilisent
+      aussi ce format. Par exemple :</p>
+
+      <highlight language="config">
+CacheEnable socache /
+CacheSocache shmcb:/path/to/datafile(512000)
+      </highlight>
+
+      <highlight language="config">
+CacheEnable socache /
+CacheSocache dbm:/path/to/datafile
+      </highlight>
+
+    </section>
+
   </section>
 
-  <section id="filehandle">
-    <title>Mise en cache de la gestion de fichier</title>
+  <section id="socache-caching">
+
+    <title>Mise en cache générale d'objets partagés à deux états de forme
+    clé/valeur</title>
 
     <related>
       <modulelist>
-        <module>mod_file_cache</module>
+        <module>mod_authn_socache</module>
+        <module>mod_socache_dbm</module>
+        <module>mod_socache_dc</module>
+        <module>mod_socache_memcache</module>
+        <module>mod_socache_shmcb</module>
+        <module>mod_ssl</module>
       </modulelist>
-      <directivelist>
-        <directive module="mod_file_cache">CacheFile</directive>
-      </directivelist>
+        <directivelist>
+          <directive module="mod_authn_socache">AuthnCacheSOCache</directive>
+          <directive module="mod_ssl">SSLSessionCache</directive>
+          <directive module="mod_ssl">SSLStaplingCache</directive>
+        </directivelist>
     </related>
+    
+    <p>Le serveur HTTP Apache fournit un cache d'objets partagés de bas
+    niveau pour la mise en cache d'informations comme les sessions SSL
+    ou les données d'authentification dans l'interface <a
+    href="socache.html">socache</a>.</p>
+
+    <p>Pour chaque implémentation un module supplémentaire est fourni
+    qui offre les services d'arrière-plan suivants :</p>
+
+    <dl>
+    <dt><module>mod_socache_dbm</module></dt>
+    <dd>Cache d'objets partagés basé sur DBM.</dd>
+    <dt><module>mod_socache_dc</module></dt>
+    <dd>Cache d'objets partagés basé sur Distcache.</dd>
+    <dt><module>mod_socache_memcache</module></dt>
+    <dd>Cache d'objets partagés basé sur Memcache.</dd>
+    <dt><module>mod_socache_shmcb</module></dt>
+    <dd>Cache d'objets partagés basé sur la mémoire partagée.</dd>
+    </dl>
+
+    <section id="mod_authn_socache-caching">
+      <title>Mise en cache des données d'authentification</title>
+
+      <related>
+        <modulelist>
+          <module>mod_authn_socache</module>
+        </modulelist>
+        <directivelist>
+          <directive module="mod_authn_socache">AuthnCacheSOCache</directive>
+        </directivelist>
+      </related>
+
+      <p>Le module <module>mod_authn_socache</module> permet la mise en
+      cache des données issues d'une authentification, diminuant ainsi
+      la charge des serveurs d'authentification d'arrière-plan.</p>
 
-    <p>Le fait d'ouvrir un fichier peut en lui-m&ecirc;me introduire un d&eacute;lai,
-    en particulier dans les syst&egrave;mes de fichiers r&eacute;partis
-    sur le r&eacute;seau. httpd
-    peut s'affranchir de ce d&eacute;lai en maintenant
-    un cache des descripteurs de fichiers
-    ouverts pour ce qui concerne les fichiers souvent
-    acc&eacute;d&eacute;s. httpd propose
-    actuellement une impl&eacute;mentation de mise en cache de la
-    gestion de fichier.</p>
-
-    <section>
-      <title>Directive CacheFile</title>
+    </section>
 
-      <p>La forme la plus &eacute;l&eacute;mentaire de mise en cache que
-      propose httpd est
-      fournie par le module <module>mod_file_cache</module>.
-      Plut&ocirc;t que de mettre en cache le contenu des fichiers, ce cache maintient
-      une table des descripteurs de fichiers ouverts. Les fichiers &agrave; mettre en
-      cache de cette mani&egrave;re sont sp&eacute;cifi&eacute;s dans le fichier de configuration
-      en utilisant la directive
-      <directive module="mod_file_cache">CacheFile</directive>.</p>
+    <section id="mod_ssl-caching">
+      <title>Mise en cache des sessions SSL</title>
 
-      <p>La directive
-      <directive module="mod_file_cache">CacheFile</directive> demande
-      &agrave; httpd
-      d'ouvrir le fichier lors de son d&eacute;marrage et de r&eacute;utiliser le descripteur
-      de fichier &eacute;labor&eacute; &agrave; cette occasion pour tous les
-      acc&egrave;s ult&eacute;rieurs &agrave; ce fichier.</p>
+      <related>
+        <modulelist>
+          <module>mod_ssl</module>
+        </modulelist>
+        <directivelist>
+          <directive module="mod_ssl">SSLSessionCache</directive>
+          <directive module="mod_ssl">SSLStaplingCache</directive>
+        </directivelist>
+      </related>
 
-      <example>
-      CacheFile /usr/local/apache2/htdocs/index.html
-      </example>
+      <p>Le module <module>mod_ssl</module> utilise l'interface
+      <code>socache</code> pour fournir un cache de session et un cache
+      de base.</p>
 
-      <p>Si vous avez l'intention de mettre en cache un grand nombre de
-      fichiers de cette mani&egrave;re, vous devez vous assurer que le nombre maximum
-      de fichiers ouverts par votre syst&egrave;me d'exploitation est correctement
-      d&eacute;fini.</p>
-
-      <p>Bien que l'utilisation de la directive
-      <directive module="mod_file_cache">CacheFile</directive>
-      n'entra&icirc;ne pas la mise en cache du contenu du fichier, cela ne signifie
-      pas qu'en cas de modification du fichier pendant
-      l'ex&eacute;cution de httpd,
-      ces changements seront pris en compte. Le fichier sera toujours servi
-      dans l'&eacute;tat o&ugrave; il &eacute;tait quand httpd a d&eacute;marr&eacute;.</p>
-
-      <p>Si le fichier est supprim&eacute; pendant l'ex&eacute;cution de
-      httpd, ce dernier
-      continuera &agrave; maintenir un descripteur de fichier ouvert et &agrave; servir le
-      fichier dans l'&eacute;tat o&ugrave; il &eacute;tait quand httpd a d&eacute;marr&eacute;. Cela signifie
-      aussi habituellement que malgr&eacute; le fait que le fichier ait &eacute;t&eacute; supprim&eacute;,
-      et ne soit
-      plus accessible par le syst&egrave;me de fichiers, l'espace lib&eacute;r&eacute; ne sera
-      restitu&eacute; qu'&agrave; l'arr&ecirc;t de httpd quand le
-      descripteur de fichier sera ferm&eacute;.</p>
     </section>
 
-
   </section>
 
-  <section id="inmemory">
-    <title>Mise en cache en m&eacute;moire</title>
+  <section id="file-caching">
+
+    <title>Mise en cache à base de fichiers spécialisés</title>
 
-     <related>
+    <related>
       <modulelist>
         <module>mod_file_cache</module>
       </modulelist>
       <directivelist>
-        <directive module="mod_cache">CacheEnable</directive>
-        <directive module="mod_cache">CacheDisable</directive>
+        <directive module="mod_file_cache">CacheFile</directive>
         <directive module="mod_file_cache">MMapFile</directive>
       </directivelist>
     </related>
 
-    <p>Servir un contenu directement depuis la m&eacute;moire syst&egrave;me est
-    universellement reconnu comme la m&eacute;thode la plus rapide. Lire des fichiers
-    depuis un contr&ocirc;leur de disque ou pire, depuis un r&eacute;seau distant est plus
-    lent de plusieurs ordres de grandeur. Les contr&ocirc;leurs de disque r&eacute;alisent
-    en g&eacute;n&eacute;ral des op&eacute;rations m&eacute;caniques, et l'acc&egrave;s au r&eacute;seau est limit&eacute; par la
-    bande passante dont vous disposez. Par contre, les temps d'acc&egrave;s &agrave; la
-    m&eacute;moire sont de l'ordre de la nano-seconde.</p>
-
-    <p>Cependant la m&eacute;moire syst&egrave;me n'est pas bon march&eacute;; &agrave; capacit&eacute; &eacute;gale,
-    c'est de loin le type de stockage le plus co&ucirc;teux et il est important de
-    s'assurer qu'elle est utilis&eacute;e efficacement. Le fait de mettre en cache
-    des fichiers en m&eacute;moire diminue d'autant la quantit&eacute; de m&eacute;moire syst&egrave;me
-    disponible. Comme nous le verrons plus loin, ce n'est pas un probl&egrave;me en
-    soi dans le cas de la mise en cache par l'interm&eacute;diaire du syst&egrave;me
-    d'exploitation, mais si l'on utilise la mise en cache en m&eacute;moire propre &agrave;
-    httpd, il faut prendre garde &agrave; ne pas allouer trop de m&eacute;moire au cache.
-    Sinon le syst&egrave;me sera contraint d'utiliser le swap, ce qui d&eacute;gradera
+    <p>Sur les plateformes où le système de fichiers peut être lent, ou
+    lorsque les descripteurs de fichiers sont gourmands en ressources,
+    il est possible de précharger des fichiers en mémoire au démarrage
+    du serveur.</p>
+
+    <p>Sur les systèmes où l'ouverture des fichiers est lente, il est
+    possible d'ouvrir le fichier au démarrage du serveur et de mettre en
+    cache le descripteur de fichier. Ces options peuvent vous aider sur
+    les systèmes où l'accès aux fichiers statiques est lent.</p>
+
+    <section id="filehandle">
+      <title>Mise en cache des descripteurs de fichier</title>
+
+      <p>Le processus d'ouverture d'un fichier peut être en soi une
+      source de ralentissement, en particulier sur les systèmes de
+      fichiers sur le réseau. httpd permet d'éviter ce ralentissement en
+      maintenant un cache des descripteurs de fichiers ouverts pour les
+      fichiers souvent servis. Actuellement, httpd fournit une seule
+      implémentation de mise en cache des descripteurs de fichiers.</p>
+
+      <section>
+        <title>CacheFile</title>
+
+        <p>La forme la plus basique de mise en cache que propose httpd
+       est la mise en cache des descripteurs de fichiers fournie par le
+       module <module>mod_file_cache</module>. Plutôt que de mettre en
+       cache le contenu des fichiers, ce cache maintient une table des
+       descripteurs de fichiers ouverts. Les fichiers devant faire
+       l'objet d'une mise en cache de ce type sont spécifiés dans le
+       fichier de configuration via la directive <directive
+       module="mod_file_cache">CacheFile</directive>.</p>
+
+        <p>La directive <directive
+       module="mod_file_cache">CacheFile</directive> informe httpd
+       qu'il doit ouvrir le fichier lors de son démarrage et qu'il doit
+       réutiliser le descripteur de fichier mis en cache pour tous les
+       accès futurs à ce fichier.</p>
+
+        <highlight language="config">
+        CacheFile /usr/local/apache2/htdocs/index.html
+        </highlight>
+
+        <p>Si vous désirez mettre en cache un grand nombre de fichiers
+       de cette manière, vous devez vous assurer que le nombre maximal
+       de fichiers ouverts pour votre système d'exploitation est défini
+       à une valeur suffisante.</p>
+
+        <p>Bien que l'utilisation de la directive <directive
+       module="mod_file_cache">CacheFile</directive> n'entraîne pas de
+       mise en cache du contenu du fichier proprement dit, elle
+       implique que si le fichier est modifié pendant l'exécution du
+       serveur, ces modifications ne seront pas prises en compte. Le
+       fichier sera toujours servi dans l'état où il se trouvait au
+       moment du démarrage du serveur.</p>
+
+        <p>Si le fichier est supprimé pendant l'exécution du serveur, ce
+       dernier conservera le descripteur de fichier ouvert associé et
+       servira le fichier dans l'état où il se trouvait au
+       moment du démarrage du serveur. Cela signifie aussi que même si
+       le fichier a été supprimé, et n'apparaît donc plus dans le
+       système de fichiers, l'espace disque libéré ne sera disponible
+       qu'une fois le serveur httpd arrêté et donc le descripteur de
+       fichier fermé.</p>
+      </section>
+
+    </section>
+
+    <section id="inmemory">
+      <title>In-Memory Caching</title>
+
+    <p>Servir un contenu directement depuis la mémoire système est
+    universellement reconnu comme la méthode la plus rapide. Lire des fichiers
+    depuis un contrôleur de disque ou pire, depuis un réseau distant est plus
+    lent de plusieurs ordres de grandeur. Les contrôleurs de disque réalisent
+    en général des opérations mécaniques, et l'accès au réseau est limité par la
+    bande passante dont vous disposez. Par contre, les temps d'accès à la
+    mémoire sont de l'ordre de la nano-seconde.</p>
+
+    <p>Cependant la mémoire système n'est pas bon marché; à capacité égale,
+    c'est de loin le type de stockage le plus coûteux et il est important de
+    s'assurer qu'elle est utilisée efficacement. Le fait de mettre en cache
+    des fichiers en mémoire diminue d'autant la quantité de mémoire système
+    disponible. Comme nous le verrons plus loin, ce n'est pas un problème en
+    soi dans le cas de la mise en cache par l'intermédiaire du système
+    d'exploitation, mais si l'on utilise la mise en cache en mémoire propre à
+    httpd, il faut prendre garde à ne pas allouer trop de mémoire au cache.
+    Sinon le système sera contraint d'utiliser le swap, ce qui dégradera
     sensiblement les performances.</p>
 
-    <section>
-      <title>Mise en cache par l'interm&eacute;diaire du syst&egrave;me d'exploitation</title>
+      <section>
+      <title>Mise en cache par l'intermédiaire du système d'exploitation</title>
 
-      <p>Dans la plupart des syst&egrave;mes d'exploitation modernes, c'est le noyau
-      qui g&egrave;re directement la mise en cache en m&eacute;moire des donn&eacute;es relatives
-      aux fichiers. C'est une fonctionnalit&eacute; puissante, et les syst&egrave;mes
+      <p>Dans la plupart des systèmes d'exploitation modernes, c'est le noyau
+      qui gère directement la mise en cache en mémoire des données relatives
+      aux fichiers. C'est une fonctionnalité puissante, et les systèmes
       d'exploitation s'en acquittent fort bien pour la plus grande partie.
-      Consid&eacute;rons par exemple, dans le cas de Linux, la diff&eacute;rence entre le
-      temps n&eacute;cessaire &agrave; la premi&egrave;re lecture d'un fichier et le temps
-      n&eacute;cessaire &agrave; sa deuxi&egrave;me lecture;</p>
+      Considérons par exemple, dans le cas de Linux, la différence entre le
+      temps nécessaire à la première lecture d'un fichier et le temps
+      nécessaire à sa deuxième lecture;</p>
 
-      <example><pre>
+        <example><pre>
 colm@coroebus:~$ time cat testfile &gt; /dev/null
 real    0m0.065s
 user    0m0.000s
@@ -569,197 +868,191 @@ colm@coroebus:~$ time cat testfile &gt; /dev/null
 real    0m0.003s
 user    0m0.003s
 sys     0m0.000s</pre>
-      </example>
+        </example>
 
-      <p>M&ecirc;me pour ce petit fichier, il y a une grande diff&eacute;rence entre les
-      temps n&eacute;cessaires pour lire le fichier. Ceci est du au fait que le
-      noyau a mis en cache le contenu du fichier en m&eacute;moire.</p>
+      <p>Même pour ce petit fichier, il y a une grande différence entre les
+      temps nécessaires pour lire le fichier. Ceci est du au fait que le
+      noyau a mis en cache le contenu du fichier en mémoire.</p>
 
-      <p>Du fait de toujours pouvoir disposer de m&eacute;moire syst&egrave;me, vous pouvez
-      &ecirc;tre assur&eacute; qu'il y aura de plus en plus de contenus de fichiers stock&eacute;s
-      dans ce cache. Ceci peut s'av&eacute;rer une m&eacute;thode de mise en cache en m&eacute;moire
-      tr&egrave;s efficace, et ne n&eacute;cessite aucune configuration suppl&eacute;mentaire
+      <p>Du fait de toujours pouvoir disposer de mémoire système, vous pouvez
+      être assuré qu'il y aura de plus en plus de contenus de fichiers stockés
+      dans ce cache. Ceci peut s'avérer une méthode de mise en cache en mémoire
+      très efficace, et ne nécessite aucune configuration supplémentaire
       de httpd.</p>
 
-      <p>De plus, comme le syst&egrave;me d'exploitation sait si des fichiers
-      ont &eacute;t&eacute;
-      supprim&eacute;s ou modifi&eacute;s, il peut effacer automatiquement des contenus de
-      fichiers du cache lorsque cela s'av&egrave;re n&eacute;cessaire. Ceci constitue un gros
-      avantage par rapport &agrave; la mise en cache en m&eacute;moire
+      <p>De plus, comme le système d'exploitation sait si des fichiers
+      ont été
+      supprimés ou modifiés, il peut effacer automatiquement des contenus de
+      fichiers du cache lorsque cela s'avère nécessaire. Ceci constitue un gros
+      avantage par rapport à la mise en cache en mémoire
       de httpd qui n'a
-      aucune possibilit&eacute; de savoir si un fichier a &eacute;t&eacute; modifi&eacute;.</p>
-    </section>
+      aucune possibilité de savoir si un fichier a été modifié.</p>
+      </section>
 
-    <p>En d&eacute;pit des performances et des avantages de la mise en cache
-    automatique par le syst&egrave;me d'exploitation, la mise en cache en m&eacute;moire
-    peut &ecirc;tre effectu&eacute;e plus efficacement par httpd dans certaines
+    <p>En dépit des performances et des avantages de la mise en cache
+    automatique par le système d'exploitation, la mise en cache en mémoire
+    peut être effectuée plus efficacement par httpd dans certaines
     circonstances.</p>
 
     <section>
-      <title>Mise en cache &agrave; l'aide de la directive MMapFile</title>
+      <title>Mise en cache à l'aide de la directive MMapFile</title>
 
       <p>La directive <directive module="mod_file_cache">MMapFile</directive>
       fournie par le module <module>mod_file_cache</module> vous permet de
-      demander &agrave; httpd de charger un contenu de fichier statique en m&eacute;moire
-      lors de son d&eacute;marrage (&agrave; l'aide de l'appel
-      syst&egrave;me mmap). httpd
-      utilisera le contenu charg&eacute; en m&eacute;moire pour satisfaire ult&eacute;rieurement
-      toutes les demandes d'acc&egrave;s &agrave; ce fichier.</p>
+      demander à httpd de charger un contenu de fichier statique en mémoire
+      lors de son démarrage (à l'aide de l'appel
+      système mmap). httpd
+      utilisera le contenu chargé en mémoire pour satisfaire ultérieurement
+      toutes les demandes d'accès à ce fichier.</p>
 
-      <example>
-      MMapFile /usr/local/apache2/htdocs/index.html
-      </example>
+        <highlight language="config">
+        MMapFile /usr/local/apache2/htdocs/index.html
+        </highlight>
 
       <p>Comme dans le cas de la directive
       <directive module="mod_file_cache">CacheFile</directive>, toute
       modification du fichier ne sera plus prise en compte par httpd une fois
-      ce dernier d&eacute;marr&eacute;.</p>
+      ce dernier démarré.</p>
 
       <p> La directive
       <directive module="mod_file_cache">MMapFile</directive> ne gardant
-      pas la trace de la quantit&eacute; de m&eacute;moire qu'elle alloue, vous devez prendre
+      pas la trace de la quantité de mémoire qu'elle alloue, vous devez prendre
       garde de ne pas en abuser. Chaque processus enfant de httpd utilisant
-      sa propre r&eacute;plique de la m&eacute;moire allou&eacute;e, il est donc d'une importance
-      critique de s'assurer que les fichiers charg&eacute;s ne sont pas d'une taille
-      trop importante afin d'&eacute;pargner au syst&egrave;me l'utilisation du swap.</p>
+      sa propre réplique de la mémoire allouée, il est donc d'une importance
+      critique de s'assurer que les fichiers chargés ne sont pas d'une taille
+      trop importante afin d'épargner au système l'utilisation du swap.</p>
+      </section>
     </section>
 
-
   </section>
 
-  <section id="disk">
-    <title>Mise en cache sur disque</title>
+  <section id="security">
+    <title>Considérations sur la sécurité</title>
 
-     <related>
-      <modulelist>
-        <module>mod_cache_disk</module>
-      </modulelist>
-      <directivelist>
-        <directive module="mod_cache">CacheEnable</directive>
-        <directive module="mod_cache">CacheDisable</directive>
-      </directivelist>
-    </related>
+    <section>
+      <title>Autorisation et contrôle d'accès</title>
 
-    <p>Le module <module>mod_cache_disk</module> fournit un m&eacute;canisme de mise
-    en cache sur disque au module <module>mod_cache</module>. Cette mise en cache est
-    intelligente et le contenu ne sera servi qu'&agrave; partir du cache tant qu'il
-    sera consid&eacute;r&eacute; comme valide.</p>
+      <p>Utiliser <module>mod_cache</module> revient sensiblement à la même
+      chose qu'avoir un mandataire inverse intégré (reverse-proxy). Les requêtes
+      seront servies par le module de mise en cache sauf si ce dernier
+      détermine qu'un processus d'arrière-plan doit être appelé. La mise en
+      cache de ressources locales modifie considérablement le modèle de
+      sécurité de httpd.</p>
+
+      <p>Comme le parcours de la hiérarchie d'un système de fichiers pour
+      examiner le contenu d'éventuels fichiers
+      <code>.htaccess</code> serait une opération très coûteuse en ressources,
+      annulant partiellement de ce fait l'intérêt de la mise en cache
+      (accélérer le traitement des requêtes),
+      <module>mod_cache</module> ne se préoccupe pas de savoir s'il a
+      l'autorisation de servir une entité mise en cache. En d'autres termes,
+      si <module>mod_cache</module> a mis en cache un certain contenu, ce
+      dernier sera servi à partir du cache tant qu'il ne sera pas arrivé à
+      expiration.</p>
 
-    <p>Typiquement, le module sera configur&eacute; comme suit :</p>
+      <p>Si par exemple, votre configuration autorise l'accès à une ressource
+      en fonction de l'adresse IP, vous devez vous assurer que ce contenu n'est
+      pas mis en cache. Ceci est possible en utilisant la directive
+      <directive module="mod_cache">CacheDisable</directive>, ou le module
+      <module>mod_expires</module>. Livré à lui-même,
+      <module>mod_cache</module> - pratiquement comme un mandataire inverse -
+      mettrait en cache le contenu lors de son service, et le servirait ensuite
+      à tout client, vers n'importe quelle adresse IP.</p>
 
-    <example>
-CacheRoot   /var/cache/apache/<br />
-CacheEnable disk /<br />
-CacheDirLevels 2<br />
-CacheDirLength 1
-    </example>
+      <p>Lorsque la directive <directive
+      module="mod_cache">CacheQuickHandler</directive> est définie à
+      <code>Off</code>, toutes les phases du traitement de la requête
+      sont exécutées et le modèle de sécurité reste le même.</p>
 
-    <p>Il est important de savoir que, les fichiers mis en cache &eacute;tant stock&eacute;s
-    localement, la mise en cache par l'interm&eacute;diaire du syst&egrave;me d'exploitation
-    sera en g&eacute;n&eacute;ral aussi appliqu&eacute;e &agrave; leurs acc&egrave;s. Si bien que m&ecirc;me si les
-    fichiers sont stock&eacute;s sur disque, s'il font l'objet d'acc&egrave;s fr&eacute;quents,
-    il est probable que le syst&egrave;me d'exploitation s'appliquera &agrave; ce qu'ils
-    soient servis &agrave; partir de la m&eacute;moire.</p>
+    </section>
 
     <section>
-      <title>Comprendre le stockage dans le cache</title>
-
-      <p>Pour stocker des entit&eacute;s dans le cache,
-      le module <module>mod_cache_disk</module> cr&eacute;e une empreinte (hash) de 22
-      caract&egrave;res de l'URL qui a fait l'objet d'une requ&ecirc;te. Cette empreinte
-      comprend le nom d'h&ocirc;te, le protocole, le port, le chemin et tout argument
-      de type CGI associ&eacute; &agrave; l'URL, afin d'&ecirc;tre sur que plusieurs URLs
-      n'interf&egrave;rent pas entre elles.</p>
+      <title>Piratages locaux</title>
 
-      <p>Chaque position de l'empreinte peut contenir un caract&egrave;re
-      choisi parmi 64 caract&egrave;res diff&eacute;rents, il y a donc
-      64^22 possibilit&eacute;s pour une empreinte. Par exemple, une URL peut poss&eacute;der
-      l'empreinte <code>xyTGxSMO2b68mBCykqkp1w</code>. Cette empreinte est
-      utilis&eacute;e pour pr&eacute;fixer les noms de fichiers sp&eacute;cifiques &agrave; cette URL &agrave;
-      l'int&eacute;rieur du cache; cependant, elle est tout d'abord plac&eacute;e dans les
-      r&eacute;pertoires du cache selon les directives
-      <directive module="mod_cache_disk">CacheDirLevels</directive> et
-      <directive module="mod_cache_disk">CacheDirLength</directive>.</p>
+      <p>Etant donné que les requêtes des utilisateurs finaux peuvent être
+      servies depuis le cache, ce dernier est une cible potentielle pour ceux
+      qui veulent défigurer un contenu ou interférer avec lui. Il est important
+      de garder à l'esprit que l'utilisateur sous lequel tourne
+      httpd doit
+      toujours avoir l'accès en écriture dans le cache. Ceci est en contraste
+      total avec la recommandation usuelle d'interdire à l'utilisateur sous
+      lequel tourne Apache
+      l'accès en écriture à tout contenu.</p>
 
-      <p>La directive
-      <directive module="mod_cache_disk">CacheDirLevels</directive>
-      d&eacute;finit le nombre de niveaux de sous-r&eacute;pertoires, et
-      <directive module="mod_cache_disk">CacheDirLength</directive>
-      le nombre de caract&egrave;res composant le nom des sous-r&eacute;pertoires. Dans
-      l'exemple donn&eacute; plus haut, l'empreinte se trouvera &agrave; :
-      <code>/var/cache/apache/x/y/TGxSMO2b68mBCykqkp1w</code>.</p>
+      <p>Si l'utilisateur sous lequel tourne Apache est compromis,
+      par exemple à cause d'une
+      faille de sécurité dans un processus CGI, il est possible que le cache
+      fasse l'objet d'une attaque. Il est relativement aisé d'insérer ou de
+      modifier une entité dans le cache en utilisant le module
+      <module>mod_cache_disk</module>.</p>
 
-      <p>Cette technique a pour but principal de r&eacute;duire le nombre de
-      sous-r&eacute;pertoires ou de fichiers contenus dans un r&eacute;pertoire particulier,
-      car le fonctionnement de la plupart des syst&egrave;mes de fichiers est ralenti
-      quand ce nombre augmente. Avec la valeur "1" pour la directive
-      <directive module="mod_cache_disk">CacheDirLength</directive>,
-      il peut y avoir au plus 64 sous-r&eacute;pertoires &agrave; un niveau quelconque.
-      Avec la valeur "2", il peut y en avoir 64 * 64, etc...
-      A moins d'avoir une bonne raison pour ne pas le faire, l'utilisation de
-      la valeur "1" pour la directive
-      <directive module="mod_cache_disk">CacheDirLength</directive>
-      est recommand&eacute;e.</p>
+      <p>Cela représente un risque relativement élévé par rapport aux autres
+      types d'attaques qu'il est possible de mener sous l'utilisateur apache.
+      Si vous utilisez <module>mod_cache_disk</module>, vous devez garder ceci
+      à l'esprit : effectuez toujours les mises à jour de
+      httpdquand des
+      correctifs de sécurité sont annoncés et exécutez les processus CGI sous
+      un utilisateur autre qu'apache en utilisant
+      <a href="suexec.html">suEXEC</a> dans la mesure du possible.</p>
 
-      <p>Le param&eacute;trage de la directive
-      <directive module="mod_cache_disk">CacheDirLevels</directive>
-      d&eacute;pend du nombre de fichiers que vous pensez stocker dans le cache.
-      Avec une valeur de "2" comme dans l'exemple donn&eacute; plus haut,
-      4096 sous-r&eacute;pertoires peuvent &ecirc;tre cr&eacute;&eacute;s au total. Avec 1 million de
-      fichiers dans le cache, cela &eacute;quivaut &agrave; environ 245 URLs mises en cache
-      dans chaque r&eacute;pertoire.</p>
-
-      <p>Chaque URL n&eacute;cessite au moins deux fichiers dans le cache. Ce sont en
-      g&eacute;n&eacute;ral un fichier ".header", qui contient des meta-informations &agrave; propos
-      de l'URL, comme la date de son arriv&eacute;e &agrave; expiration,
-      et un fichier ".data" qui est la copie exacte du contenu &agrave; servir.</p>
-
-      <p>Dans le cas d'un contenu n&eacute;goci&eacute; via l'en-t&ecirc;te "Vary", un r&eacute;pertoire
-      ".vary" sera cr&eacute;&eacute; pour l'URL en question. Ce r&eacute;pertoire contiendra de
-      multiples fichiers ".data" correspondant aux diff&eacute;rents contenus
-      n&eacute;goci&eacute;s.</p>
     </section>
 
     <section>
-      <title>Maintenance du cache sur disque</title>
-
-      <p>Bien que le module <module>mod_cache_disk</module> supprime un contenu
-      du cache lorsqu'il est arriv&eacute; &agrave; expiration, il ne maintient aucune
-      information &agrave; propos de la taille totale du cache ou de l'espace restant
-      disponible.</p>
-
-      <p>Par contre l'utilitaire
-      <a href="programs/htcacheclean.html">htcacheclean</a> fourni avec
-      httpd
-      vous permet, comme son nom l'indique, de nettoyer le cache p&eacute;riodiquement.
-      D&eacute;terminer la fr&eacute;quence &agrave; laquelle lancer <a
-      href="programs/htcacheclean.html">htcacheclean</a> et la taille souhait&eacute;e
-      pour le cache est une t&acirc;che relativement complexe et il vous faudra de
-      nombreux essais et erreurs pour arriver &agrave; s&eacute;lectionner des valeurs
-      optimales.</p>
+      <title>Empoisonnement du cache (Cache Poisoning)</title>
 
-      <p><a href="programs/htcacheclean.html">htcacheclean</a> op&egrave;re selon deux
-      modes. Il peut s'ex&eacute;cuter comme d&eacute;mon r&eacute;sident, ou &ecirc;tre lanc&eacute;
-      p&eacute;riodiquement par cron. <a
-      href="programs/htcacheclean.html">htcacheclean</a> peut mettre une heure
-      ou plus pour traiter de tr&egrave;s grands caches (plusieurs dizaines de
-      Gigaoctets) et si vous l'ex&eacute;cutez &agrave; partir de cron, il vous est
-      conseill&eacute; de d&eacute;terminer la dur&eacute;e typique d'un traitement, afin d'&eacute;viter
-      d'ex&eacute;cuter plusieurs instances &agrave; la fois.</p>
+      <p>Si vous utilisez httpd comme serveur mandataire avec mise en cache,
+      vous vous exposez aussi à un éventuel "Empoisonnement du
+      cache" (Cache poisoning). L'empoisonnement du cache est un terme général
+      pour désigner les attaques au cours desquelles l'attaquant fait en sorte
+      que le serveur mandataire renvoie à un contenu incorrect (et souvent
+      indésirable) suite à en provenance du serveur d'arrière-plan.
+      </p>
 
-      <p class="figure">
-      <img src="images/caching_fig1.gif" alt="" width="600"
-          height="406" /><br />
-      <a id="figure1" name="figure1"><dfn>Figure 1</dfn></a>: Croissance
-      typique du cache / s&eacute;quence de nettoyage.</p>
+      <p>Par exemple, si les serveur DNS qu'utilise votre système où tourne
+      httpd sont vulnérables à l'empoisonnement du cache des DNS, un attaquant
+      pourra contrôler vers où httpd se connecte lorsqu'il demande un contenu
+      depuis le serveur d'origine.
+      Un autre exemple est constitué par les attaques ainsi nommées
+      "Dissimulation de requêtes HTTP" (HTTP request-smuggling).</p>
 
-      <p>Comme <module>mod_cache_disk</module> ne tient pas compte de l'espace
-      utilis&eacute; dans le cache, vous devez vous assurer que
-      <a href="programs/htcacheclean.html">htcacheclean</a> est configur&eacute; de
-      fa&ccedil;on &agrave; laisser suffisamment d'"espace de croissance"
-      &agrave; la suite d'un nettoyage.</p>
+      <p>Ce document n'est pas le bon endroit pour une discussion approfondie
+      à propos de la Dissimulation de requêtes HTTP (utilisez plutôt votre
+      moteur de recherche favori); il est cependant important de savoir qu'il
+      est possible d'élaborer une série de requêtes, et d'exploiter une
+      vulnérabilité d'un serveur web d'origine de telle façon que l'attaquant
+      puisse contrôler entièrement le contenu renvoyé par le mandataire.</p>
     </section>
 
+    <section>
+      <title>Déni de Service / Cachebusting</title>
+
+      <p>Le mécanisme utilisé via l'en-tête Vary permet de mettre en
+      cache simultanément plusieurs variantes d'une ressource avec la
+      même URL. Le cache sélectionne la variante correcte à envoyer au
+      client en fonction des valeurs d'en-tête fournies par ce dernier.
+      Ce mécanisme peut devenir un problème lorsqu'on tente d'appliquer
+      le mécanisme des variantes à un en-tête connu pour pouvoir
+      posséder un grand nombre de valeurs
+      possibles en utilisation normal, comme par exemple l'en-tête
+      <code>User-Agent</code>. En fonction de la popularité du site web,
+      des milliers ou même des millions d'entrées de cache dupliquées
+      peuvent être créées pour la même URL, submergeant les autres
+      entrées du cache.</p>
+      
+      <p>Dans d'autres cas, il peut être nécessaire de modifier l'URL
+      d'une ressource particulière à chaque requête, en général en lui
+      ajoutant une chaîne "cachebuster". Si ce contenu est déclaré comme
+      pouvant être mis en cache par un serveur avec une durée de
+      fraîcheur significative, ces entrées peuvent submerger les entrées
+      légitimes du cache. Alors que <module>mod_cache</module> fournit
+      une directive <directive
+      module="mod_cache">CacheIgnoreURLSessionIdentifiers</directive>,
+      cette dernière doit être utilisée avec prudence pour s'assurer que
+      les caches du navigateur ou du mandataire le plus proche
+      (downstream proxy) ne sont pas victimes du même problème de Déni de
+      service.</p>
+    </section>
   </section>
 
+
 </manualpage>