2 <!DOCTYPE modulesynopsis SYSTEM "../style/modulesynopsis.dtd">
3 <?xml-stylesheet type="text/xsl" href="../style/manual.fr.xsl"?>
4 <!-- English Revision : 420990 -->
5 <!-- French translation : Lucien GENTIS -->
6 <!-- Reviewed by : Vincent Deffontaines -->
9 Licensed to the Apache Software Foundation (ASF) under one or more
10 contributor license agreements. See the NOTICE file distributed with
11 this work for additional information regarding copyright ownership.
12 The ASF licenses this file to You under the Apache License, Version 2.0
13 (the "License"); you may not use this file except in compliance with
14 the License. You may obtain a copy of the License at
16 http://www.apache.org/licenses/LICENSE-2.0
18 Unless required by applicable law or agreed to in writing, software
19 distributed under the License is distributed on an "AS IS" BASIS,
20 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21 See the License for the specific language governing permissions and
22 limitations under the License.
25 <modulesynopsis metafile="mod_deflate.xml.meta">
27 <name>mod_deflate</name>
28 <description>Comprime le contenu avant de le servir au
30 <status>Extension</status>
31 <sourcefile>mod_deflate.c</sourcefile>
32 <identifier>deflate_module</identifier>
35 <p>Le module <module>mod_deflate</module> implémente le filtre de
36 sortie <code>DEFLATE</code> qui permet de comprimer la sortie de
37 votre serveur avant de l'envoyer au client sur le réseau.</p>
39 <seealso><a href="../filter.html">Les filtres</a></seealso>
41 <section id="recommended"><title>Exemples de configurations</title>
42 <p>Voici un exemple simple de configuration pour les
45 <example><title>Ne comprime que certains types de documents</title>
46 AddOutputFilterByType DEFLATE text/html text/plain text/xml
49 <p>La configuration suivante, tout en produisant un contenu encore
50 plus comprimé, est aussi beaucoup plus compliquée. N'utilisez pas
51 cet exemple si vous ne comprenez pas tous les détails de la
54 <example><title>Comprime tout, sauf les images</title>
55 <Location /><br />
57 # Insère le filtre<br />
58 SetOutputFilter DEFLATE<br />
60 # Netscape 4.x a quelques problèmes ...<br />
61 BrowserMatch ^Mozilla/4 gzip-only-text/html<br />
63 # Netscape 4.06-4.08 ont d'autres problèmes<br />
64 BrowserMatch ^Mozilla/4\.0[678] no-gzip<br />
66 # MSIE se fait passer pour Netscape, mais ça marche<br />
67 BrowserMatch \bMSIE !no-gzip !gzip-only-text/html<br />
68 # Ne pas comprimer les images<br />
69 SetEnvIfNoCase Request_URI \<br />
71 \.(?:gif|jpe?g|png)$ no-gzip dont-vary<br />
74 # On s'assure que les mandataires ne servent pas le mauvais
76 Header append Vary User-Agent env=!dont-vary<br />
83 <section id="enable"><title>Activation de la compression</title>
85 <section id="output"><title>Compression de la sortie</title>
86 <p>La compression est implémentée par le <a
87 href="../filter.html">filtre</a> <code>DEFLATE</code>. La
88 directive suivante active la compression des documents dans le
89 conteneur où elle est placée :</p>
92 SetOutputFilter DEFLATE
95 <p>Certains navigateurs populaires ne gèrent pas la compression de
96 tous les contenus, et pour résoudre ce problème, vous pouvez
97 définir la note <code>gzip-only-text/html</code> à <code>1</code>
98 pour ne permettre que la compression des fichiers html (voir
99 ci-dessous). Si vous définissez cette note à <em>toute autre
100 valeur que <code>1</code></em>, elle sera ignorée.</p>
102 <p>Si vous voulez limiter la compression à certains types MIME
103 particuliers, vous pouvez utiliser la directive <directive
104 module="core">AddOutputFilterByType</directive>. Voici un exemple
105 où la compression n'est activée que pour les fichiers html de la
106 documentation d'Apache :</p>
109 <Directory "/racine-de-votre-serveur/manual"><br />
111 AddOutputFilterByType DEFLATE text/html<br />
116 <p>Pour les navigateurs qui ont des problèmes avec la compression
117 de tous les types de fichiers, vous pouvez utiliser la directive
118 <directive module="mod_setenvif">BrowserMatch</directive> pour
119 définir la note <code>no-gzip</code>, pour le navigateur
120 considéré, de façon à ce qu'aucune compression ne soit effectuée.
121 Vous pouvez combiner <code>no-gzip</code> avec
122 <code>gzip-only-text/html</code> afin d'obtenir le meilleur
123 résultat possible. Dans ce cas, la première note l'emporte sur la
124 deuxième. Considérons l'extrait suivant de l'<a
125 href="#recommended">exemple de configuration</a> de la section
126 précédente :</p>
129 BrowserMatch ^Mozilla/4 gzip-only-text/html<br />
130 BrowserMatch ^Mozilla/4\.0[678] no-gzip<br />
131 BrowserMatch \bMSIE !no-gzip !gzip-only-text/html
134 <p>Tout d'abord, on recherche un en-tête <code>User-Agent</code>
135 qui signale un navigateur Netscape version 4.x. Ces versions ne
136 gèrent pas la compression des types de fichiers autres que
137 <code>text/html</code>. En outre, les versions 4.06, 4.07 et 4.08
138 ont des problèmes avec la décompression des fichiers html. Par
139 conséquent, nous désactivons complètement le filtre deflate pour
142 <p>La troisième directive <directive
143 module="mod_setenvif">BrowserMatch</directive> corrige l'identité
144 sous laquelle se présente le navigateur ; en effet, Microsoft
145 Internet Explorer s'identifie aussi lui-même comme "Mozilla/4",
146 mais par contre, il sait gérer les contenus compressés. On
147 recherche donc la chaîne additionnelle "MSIE" (<code>\b</code>
148 signifie "par mots entiers") dans l'en-tête
149 <code>User-Agent</code>, et si elle est trouvée, on annule les
150 restrictions définies auparavant.</p>
152 <note><title>Note</title>
153 Le filtre <code>DEFLATE</code> est toujours inséré après les
154 filtres RESOURCE comme PHP ou SSI. Il n'affecte jamais les
155 sous-requêtes internes.
157 <note><title>Note</title>
158 La variable d'environnement <code>force-gzip</code>, définie à
159 l'aide de la directive <directive
160 module="core">SetEnv</directive>, permet d'ignorer la
161 configuration de votre navigateur quant aux codages acceptés, et
162 d'envoyer sans condition une sortie comprimée.
166 <section id="inflate"><title>Décompression de la sortie</title>
167 <p>Le module <module>mod_deflate</module> fournit aussi un filtre
168 permettant de décomprimer un corps de réponse comprimé par gzip.
169 Pour activer cette fonctionnalité, vous devez insérer le filtre
170 <code>INFLATE</code> dans la chaîne de filtrage en sortie via la
171 directive <directive module="core">SetOutputFilter</directive> ou
172 <directive module="mod_mime">AddOutputFilter</directive>, comme
173 dans l'exemple suivant :</p>
176 <Location /dav-area><br />
178 ProxyPass http://example.com/<br />
179 SetOutputFilter INFLATE<br />
184 <p>Dans cet exemple, les sorties comprimées par gzip en
185 provenance de example.com seront décomprimées afin de pouvoir
186 être éventuellement traitées par d'autres filtres.
190 <section id="input"><title>Décompression de l'entrée</title>
191 <p>Le module <module>mod_deflate</module> fournit également un filtre
192 permettant de décomprimer un corps de requête comprimé par gzip.
193 Pour activer cette fonctionnalité, vous devez insérer le filtre
194 <code>DEFLATE</code> dans la chaîne de filtrage en entrée via la
195 directive <directive module="core">SetInputFilter</directive> ou
196 <directive module="mod_mime">AddInputFilter</directive>, comme
197 dans l'exemple suivant :</p>
200 <Location /dav-area><br />
202 SetInputFilter DEFLATE<br />
207 <p>Désormais, si une requête contient un en-tête
208 <code>Content-Encoding: gzip</code>, son corps sera
209 automatiquement décomprimé. Peu de navigateurs sont actuellement
210 en mesure de comprimer les corps de requêtes. Cependant,
211 certaines applications spécialisées supportent les requêtes
212 comprimées, comme par exemple certains clients <a
213 href="http://www.webdav.org">WebDAV</a>.</p>
215 <note type="warning"><title>Note à propos de l'en-tête
216 <code>Content-Length</code></title>
217 <p>Si vous évaluez vous-même la taille du corps de requête,
218 <em>ne faites pas confiance à l'en-tête
219 <code>Content-Length</code>!</em> L'en-tête
220 Content-Length indique la longueur des données en provenance du
221 client, et <em>non</em> la quantité d'octets que représente le
222 flux de données décompressé.</p>
227 <section id="proxies"><title>Prise en compte des serveurs mandataires</title>
229 <p>Le module <module>mod_deflate</module> envoie un en-tête de
230 réponse HTTP <code>Vary: Accept-Encoding</code> pour avertir les
231 mandataires qu'une réponse enregistrée dans le cache ne doit être
232 envoyée qu'aux clients qui ont envoyé l'en-tête de requête
233 <code>Accept-Encoding</code> approprié. Ceci permet d'éviter l'envoi
234 d'un contenu comprimé à un client qui ne sera pas en mesure
235 de l'interpréter.</p>
237 <p>Si vous avez défini des exclusions spécifiques dépendant, par
238 exemple, de l'en-tête <code>User-Agent</code>, vous devez
239 ajouter manuellement des données à l'en-tête <code>Vary</code> afin
240 d'informer les mandataires des restrictions supplémentaires. Par
241 exemple, dans la configuration classique où l'addition du filtre
242 <code>DEFLATE</code> dépend du contenu de l'en-tête
243 <code>User-Agent</code>, vous devez spécifier :</p>
246 Header append Vary User-Agent
249 <p>Si votre décision de comprimer le contenu dépend d'autres
250 informations que celles contenues dans les en-têtes de la requête
251 (par exemple la version HTTP), vous devez attribuer à l'en-tête
252 <code>Vary</code> la valeur <code>*</code>, ce qui permet d'empêcher
253 les mandataires compatibles de tout mettre en cache.</p>
255 <example><title>Exemple</title>
261 <name>DeflateFilterNote</name>
262 <description>Enregistre le taux de compression sous la forme d'une note
263 à des fins de journalisation</description>
264 <syntax>DeflateFilterNote [<var>type</var>] <var>nom de la note</var></syntax>
265 <contextlist><context>server config</context><context>virtual host</context>
267 <compatibility><var>type</var> est disponible depuis la version 2.0.45
268 d'Apache</compatibility>
271 <p>La directive <directive>DeflateFilterNote</directive> permet de
272 spécifier qu'une note à propos du taux de compression doit être
273 attachée à la requête. Le nom de la note est passé sous la forme
274 d'un argument de la directive. Vous pouvez utiliser cette note à des
275 fins statistiques en enregistrant sa valeur dans votre <a
276 href="../logs.html#accesslog">journal des accès</a>.</p>
278 <example><title>Exemple</title>
279 DeflateFilterNote ratio<br />
281 LogFormat '"%r" %b (%{ratio}n) "%{User-agent}i"' deflate<br />
282 CustomLog logs/deflate_log deflate
285 <p>Pour extraire des informations plus précises de vos journaux,
286 vous pouvez utiliser l'argument <var>type</var> pour spécifier le
287 type de données de la note enregistrée dans le journal.
288 <var>type</var> peut prendre une des valeurs suivantes :</p>
291 <dt><code>Input</code></dt>
292 <dd>Enregistre dans la note la taille en octets du flux en entrée
295 <dt><code>Output</code></dt>
296 <dd>Enregistre dans la note la taille en octets du flux en sortie
299 <dt><code>Ratio</code></dt>
300 <dd>Enregistre le taux de compression (<code>sortie/entrée *
301 100</code>) dans la note. Il s'agit de la valeur par défaut si
302 l'argument <var>type</var> est omis.</dd>
305 <p>Vous pouvez donc configurer votre journalisation de la manière
308 <example><title>Journalisation détaillée</title>
309 DeflateFilterNote Input instream<br />
310 DeflateFilterNote Output outstream<br />
311 DeflateFilterNote Ratio ratio<br />
313 LogFormat '"%r" %{outstream}n/%{instream}n (%{ratio}n%%)' deflate<br />
314 CustomLog logs/deflate_log deflate
317 <seealso><module>mod_log_config</module></seealso>
321 <name>DeflateBufferSize</name>
322 <description>Taille du fragment que zlib devra comprimer en une seule
324 <syntax>DeflateBufferSize <var>valeur</var></syntax>
325 <default>DeflateBufferSize 8096</default>
326 <contextlist><context>server config</context><context>virtual host</context>
330 <p>La directive <directive>DeflateBufferSize</directive> permet de
331 spécifier la taille en octets du fragment que zlib devra comprimer
332 en une seule fois.</p>
337 <name>DeflateWindowSize</name>
338 <description>Taille de la fenêtre de compression zlib</description>
339 <syntax>DeflateWindowSize <var>valeur</var></syntax>
340 <default>DeflateWindowSize 15</default>
341 <contextlist><context>server config</context><context>virtual host</context>
345 <p>La directive <directive>DeflateWindowSize</directive> permet de
346 spécifier la fenêtre de compression zlib (une valeur comprise entre
347 1 et 15). En général, plus grande sera la taille de la fenêtre, plus
348 grand sera le taux de compression auquel on pourra s'attendre.</p>
354 <name>DeflateMemLevel</name>
355 <description>La quantité de mémoire utilisable par zlib pour la
356 compression</description>
357 <syntax>DeflateMemLevel <var>valeur</var></syntax>
358 <default>DeflateMemLevel 9</default>
359 <contextlist><context>server config</context><context>virtual host</context>
363 <p>La directive <directive>DeflateMemLevel</directive> permet de
364 spécifier la quantité de mémoire utilisable par zlib pour la
365 compression (une valeur comprise entre 1 et 9).</p>
370 <name>DeflateCompressionLevel</name>
371 <description>Le niveau de compression que nous appliquons à la
373 <syntax>DeflateCompressionLevel <var>valeur</var></syntax>
374 <default>La valeur par défaut de zlib</default>
375 <contextlist><context>server config</context><context>virtual host</context>
377 <compatibility>Cette directive est disponible depuis la version 2.0.45
378 d'Apache</compatibility>
381 <p>La directive <directive>DeflateCompressionLevel</directive>
382 permet de spécifier le niveau de compression à utiliser ; plus
383 grande est la valeur, meilleure sera la compression, mais plus grand
384 sera aussi le temps CPU nécessaire pour effectuer le
386 <p>La valeur doit être comprise entre 1 (compression minimale) et 9
387 (compression maximale).</p>