]> granicus.if.org Git - apache/blob - docs/manual/dns-caveats.xml.fr
Updates.
[apache] / docs / manual / dns-caveats.xml.fr
1 <?xml version="1.0" encoding="ISO-8859-1" ?>
2 <!DOCTYPE manualpage SYSTEM "./style/manualpage.dtd">
3 <?xml-stylesheet type="text/xsl" href="./style/manual.fr.xsl"?>
4 <!-- English Revision : 1332626 -->
5 <!-- French translation : Lucien GENTIS -->
6 <!-- Reviewed by : Vincent Deffontaines -->
7
8 <!--
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
15
16      http://www.apache.org/licenses/LICENSE-2.0
17
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.
23 -->
24
25 <manualpage metafile="dns-caveats.xml.meta">
26
27   <title>Probl&egrave;mes li&eacute;s au DNS avec le serveur HTTP Apache</title>
28
29   <summary>
30     <p>Cette page pourrait se r&eacute;sumer ainsi : configurez le
31     serveur HTTP Apache de fa&ccedil;on
32     &agrave; ce qu'il n'ait pas besoin de r&eacute;solution DNS pour interpr&eacute;ter les
33     fichiers de configuration. Si httpd doit effectuer des r&eacute;solutions
34     DNS pour interpr&eacute;ter les fichiers de configuration, votre serveur
35     pourra pr&eacute;senter des probl&egrave;mes de fiabilit&eacute; (en d'autres termes,
36     il est possible qu'il refuse de d&eacute;marrer), ou d'attaques par d&eacute;ni ou
37     usurpation de service (y compris l'attribution de requ&ecirc;tes &agrave; un
38     serveur virtuel autre que le serveur virtuel voulu).</p>
39   </summary>
40
41   <section id="example">
42     <title>Un exemple simple</title>
43
44     <highlight language="config">
45 # Ceci est un exemple de mauvaise configuration ; ne l'utilisez pas comme base
46 # de configuration
47 &lt;VirtualHost www.example.dom&gt;
48   ServerAdmin webgirl@example.dom
49   DocumentRoot /www/example
50 &lt;/VirtualHost&gt;
51     </highlight>
52
53     <p>Pour fonctionner correctement, le serveur a absolument besoin de deux
54     informations &agrave; propos de chaque serveur virtuel : le nom du serveur
55     d&eacute;fini par la directive <directive
56     module="core">ServerName</directive>, et au moins une adresse IP &agrave;
57     laquelle le serveur va se rattacher et r&eacute;pondre. L'exemple ci-dessus
58     ne comporte pas d'adresse IP, si bien que httpd devra utiliser le
59     DNS pour trouver l'adresse IP de <code>www.example.dom</code>. Si pour
60     une raison quelconque, le DNS n'est pas disponible au moment o&ugrave;
61     votre serveur interpr&egrave;te son fichier de configuration, ce serveur
62     virtuel <strong>ne sera pas pris en compte dans la
63     configuration</strong>. Il sera incapable de
64     r&eacute;pondre &agrave; toute requ&ecirc;te pour ce serveur virtuel.</p>
65
66     <p>Supposons que l'adresse de <code>www.example.dom</code> soit
67     192.0.2.1, et examinons cet extrait de configuration :</p>
68
69     <highlight language="config">
70 # Ceci est un exemple de mauvaise configuration ; ne l'utilisez pas comme base
71 # de configuration
72 &lt;VirtualHost 192.0.2.1&gt;
73   ServerAdmin webgirl@example.dom
74   DocumentRoot /www/example
75 &lt;/VirtualHost&gt;
76     </highlight>
77
78     <p>Cette fois, httpd doit effectuer une recherche DNS inverse pour
79     trouver le nom <code>ServerName</code> de ce serveur virtuel. Si
80     cette recherche inverse &eacute;choue, le serveur virtuel sera
81     partiellement d&eacute;sactiv&eacute;. Si le serveur
82     virtuel est &agrave; base de nom, il sera en fait totalement d&eacute;sactiv&eacute;,
83     mais s'il est &agrave; base d'adresse IP, il fonctionnera probablement.
84     Cependant, httpd &eacute;chouera s'il doit g&eacute;n&eacute;rer une URL compl&egrave;te pour
85     le serveur qui inclut ce nom de serveur (comme dans le cas d'une
86     redirection).</p>
87
88     <p>Voici un extrait de configuration qui permet d'&eacute;viter ces deux
89     types de probl&egrave;mes :</p>
90
91     <highlight language="config">
92 &lt;VirtualHost 192.0.2.1&gt;
93   ServerName www.example.dom
94   ServerAdmin webgirl@example.dom
95   DocumentRoot /www/example
96 &lt;/VirtualHost&gt;
97     </highlight>
98   </section>
99
100   <section id="denial">
101     <title>D&eacute;ni de service</title>
102
103     <p>Consid&eacute;rons cet extrait de configuration :</p>
104
105     <highlight language="config">
106 &lt;VirtualHost www.example1.dom&gt;
107   ServerAdmin webgirl@example1.dom
108   DocumentRoot /www/example1
109 &lt;/VirtualHost&gt;
110 &lt;VirtualHost www.example2.dom&gt;
111   ServerAdmin webguy@example2.dom
112   DocumentRoot /www/example2
113 &lt;/VirtualHost&gt;
114     </highlight>
115
116     <p>Supposons que vous ayez assign&eacute; 192.0.2.1 &agrave;
117     <code>www.example1.dom</code> et 192.0.2.2 &agrave; <code>www.example2.dom</code>. En
118     outre, supposons que <code>example1.dom</code> g&egrave;re son propre DNS. Avec
119     cette configuration, <code>example1.dom</code> sera en mesure de
120     d&eacute;tourner tout trafic destin&eacute; &agrave; <code>example2.dom</code>. Pour y
121     parvenir, tout ce qu'ils ont &agrave; faire consiste &agrave;
122     assigner 192.0.2.2 &agrave;
123     <code>www.example1.dom</code>. Comme ils g&egrave;rent leur propre DNS, vous ne
124     pouvez pas les emp&ecirc;cher de faire pointer l'enregistrement
125     <code>www.example1.dom</code> vers l'adresse qu'ils veulent.</p>
126
127     <p>Les requ&ecirc;tes &agrave; destination de 192.0.2.2 (y compris toutes celles
128     o&ugrave; l'utilisateur &agrave; tap&eacute; une URL de la forme
129     <code>http://www.example2.dom/quelquepart</code>), seront toutes servies
130     par le serveur virtuel <code>example1.dom</code>. Une meilleur
131     compr&eacute;hension de la raison pour laquelle ceci peut se produire
132     n&eacute;cessite une discussion plus approfondie &agrave; propos de la mani&egrave;re
133     dont httpd associe les requ&ecirc;tes entrantes aux diff&eacute;rents serveurs
134     virtuels qui vont les servir. Un document de base d&eacute;crivant ceci <a
135     href="vhosts/details.html">est disponible</a>.</p>
136   </section>
137
138   <section id="main">
139     <title>L'adresse du "serveur principal"</title>
140
141     <p><a href="vhosts/name-based.html">Le support des
142     serveurs virtuels &agrave; base de nom</a> oblige httpd &agrave;
143     conna&icirc;tre la/les adresse(s) IP de l'h&ocirc;te sur
144     lequel <program>httpd</program> s'ex&eacute;cute. Pour obtenir cette
145     adresse, soit il utilise la directive <directive
146     module="core">ServerName</directive> globale (si elle est pr&eacute;sente),
147     soit il fait appel &agrave; la fonction C <code>gethostname</code> (qui
148     doit renvoyer le m&ecirc;me nom que la commande shell "hostname"). Il
149     effectue ensuite une recherche DNS sur cette adresse. Pour le
150     moment, il n'existe aucun moyen d'&eacute;viter cette recherche DNS.</p>
151
152     <p>Si vous craignez que cette recherche DNS &eacute;choue parce que votre
153     serveur DNS est arr&ecirc;t&eacute;, vous pouvez ins&eacute;rer le nom d'h&ocirc;te dans le
154     fichier <code>/etc/hosts</code> (o&ugrave; il est probablement d&eacute;j&agrave;
155     enregistr&eacute; afin que la machine d&eacute;marre correctement). Assurez-vous
156     ensuite que la machine est configur&eacute;e pour utiliser
157     <code>/etc/hosts</code> dans le cas o&ugrave; la recherche DNS &eacute;choue.
158     Suivant le syst&egrave;me d'exploitation que vous utilisez, vous y
159     parviendrez en &eacute;ditant <code>/etc/resolv.conf</code>, ou
160     <code>/etc/nsswitch.conf</code>.</p>
161
162     <p>Si votre serveur n'a aucune autre raison d'effectuer des
163     recherches DNS, vous pouvez d&eacute;finir la variable d'environnement
164     <code>HOSTRESORDER</code> &agrave; "local", et vous serez alors en mesure
165     d'ex&eacute;cuter httpd. Tout d&eacute;pend du syst&egrave;me d'exploitation et des
166     biblioth&egrave;ques de r&eacute;solution de noms que vous utilisez. Elle affecte
167     aussi les programmes CGI, &agrave; moins que vous n'utilisiez
168     <module>mod_env</module> pour contr&ocirc;ler l'environnement. Il est
169     conseill&eacute; de consulter les pages de manuel ou les FAQs de votre
170     syst&egrave;me d'exploitation.</p>
171   </section>
172
173   <section id="tips">
174     <title>Conseils pour &eacute;viter ce genre de probl&egrave;me</title>
175
176     <ul>
177       <li>
178         utilisez des adresses IP au sein des <directive
179         module="core">VirtualHost</directive>
180       </li>
181
182       <li>
183         utilisez des adresses IP avec la directive <directive
184         module="mpm_common">Listen</directive>
185       </li>
186
187       <li>
188         v&eacute;rifiez que tous les serveurs virtuels poss&egrave;dent un nom
189         <directive module="core">ServerName</directive> explicite
190       </li>
191
192       <li>cr&eacute;ez un serveur virtuel <code>&lt;VirtualHost
193       _default_:*&gt;</code> qui n'a aucune page &agrave; servir</li>
194     </ul>
195   </section>
196
197 </manualpage>