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: 105989 -->
7 Copyright 2004 The Apache Software Foundation
9 Licensed under the Apache License, Version 2.0 (the "License");
10 you may not use this file except in compliance with the License.
11 You may obtain a copy of the License at
13 http://www.apache.org/licenses/LICENSE-2.0
15 Unless required by applicable law or agreed to in writing, software
16 distributed under the License is distributed on an "AS IS" BASIS,
17 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 See the License for the specific language governing permissions and
19 limitations under the License.
22 <manualpage metafile="install.xml.meta">
24 <title>Compilation et Installation</title>
28 <p>Ce document couvre la compilation et l'installation d'Apache sur les
29 systèmes Unix et clones d'Unix. Pour la compilation et l'installation sous
30 Windows, voir <a href="platform/windows.html">Utiliser Apache sous Windows
31 </a>. Pour les autres plates-formes, voir la documentation des <a
32 href="platform/">plates-formes</a>.</p>
34 <p>L'environnement de configuration et d'installation d'Apache 2.0 a été
35 complétement revu par rapport à celui d'Apache 1.3. Apache 1.3 utilisait un
36 ensemble de scripts pour permettre une installation facile. Apache 2.0
37 utilise à présent <code>libtool</code> et <code>autoconf</code> afin de
38 créer un environnement le plus proche possible d'autres projets
41 <p>Si vous faite une mise à niveau d'une version mineure à la suivante (par
42 exemple, de 2.0.50 à 2.0.51), veuillez s'il vous plaît passer directement à
43 la section <a href="#upgrading">Mise à niveau</a>.</p>
47 <seealso><a href="programs/configure.html">Configurer l'arborescence source</a></seealso>
48 <seealso><a href="invoking.html">Démarrage d'Apache</a></seealso>
49 <seealso><a href="stopping.html">Arrêt et Redémarrage</a></seealso>
51 <section id="overview"><title>Survol Rapide pour les
55 <columnspec><column width=".13"/><column width=".80"/></columnspec>
57 <td><a href="#download">Télécharger</a></td>
59 <td><code>$ lynx http://httpd.apache.org/download.cgi</code>
64 <td><a href="#extract">Extraire</a></td>
66 <td><code>$ gzip -d httpd-2_1_<em>NN</em>.tar.gz<br />
67 $ tar xvf httpd-2_1_<em>NN</em>.tar</code> </td>
71 <td><a href="#configure">Configurer</a></td>
73 <td><code>$ ./configure --prefix=<em>PREFIX</em></code>
78 <td><a href="#compile">Compiler</a></td>
80 <td><code>$ make</code> </td>
84 <td><a href="#install">Installer</a></td>
86 <td><code>$ make install</code> </td>
90 <td><a href="#customize">Personnaliser</a></td>
92 <td><code>$ vi <em>PREFIX</em>/conf/httpd.conf</code> </td>
96 <td><a href="#test">Tester</a></td>
98 <td><code>$ <em>PREFIX</em>/bin/apachectl start</code>
103 <p><em>NN</em> doit être remplacé par le numéro de version mineure actuel, et
104 <em>PREFIX</em> par le chemin où le serveur doit être installé. Si
105 <em>PREFIX</em> n'est pas spécifié, l'installation se fait dans
106 <code>/usr/local/apache2</code>.</p>
108 <p>Chacune des sections du processus de compilation et d'installation est
109 décrite ci-après, en commençant par les pré-requis à la compilation et à
110 l'installation d'Apache HTTPD.</p>
113 <section id="requirements"><title>Pré-requis</title>
115 <p>Les pré-requis suivants sont nécessaire pour l'installation d'Apache:</p>
118 <dt>Espace Disque</dt>
119 <dd>Au moins 50 Mo d'espace disque temporaire sont nécessaires. Après
120 installation, Apache occupe environ 10 Mo sur le disque. L'espace disque
121 occupé par une installation complète dépend beaucoup de la configuration
122 du serveur, ainsi que de la présence éventuelle de modules tiers.</dd>
124 <dt>Compilateur C ANSI et Build</dt>
125 <dd>Un compilateur C ANSI doit être utilisé. Le <a
126 href="http://www.gnu.org/software/gcc/gcc.html">compilateur C GNU
127 (GCC)</a> de la <a href="http://www.gnu.org/">Free Software Foundation
128 (FSF)</a> est recommandé (la version 2.7.2 convient). En cas
129 d'absence de GCC, vérifiez que le compilateur fourni avec l'architecture
130 utilisée est conforme aux normes ANSI. De plus, les outils de constructions
131 de base, tel <code>make</code>, doivent être présents dans votre
132 <code>PATH</code>.</dd>
134 <dt>S'assurer que la machine est et reste à l'heure</dt>
135 <dd>Certains éléments du protocole HTTP sont exprimés en tant qu'heure de
136 la journée. Aussi est-il important de s'assurer que le système où Apache
137 doit tourner dispose de mécanismes de synchronisation temporelle. En
138 général, les programmes <code>ntpdate</code> ou <code>xntpd</code> sont
139 utilisés; ces programmes implémentent le Network Time Protocol (NTP).
140 Voir le groupe Usenet <a
141 href="news:comp.protocols.time.ntp">comp.protocols.time.ntp</a> et la <a
142 href="http://www.eecis.udel.edu/~ntp/">page NTP</a> pour plus de détails
143 sur les logiciels NTP et les serveurs de temps publics.</dd>
145 <dt><a href="http://www.perl.org/">Perl 5</a>
147 <dd>Certains des scripts fournis avec Apache, tel <a
148 href="programs/apxs.html">apxs</a> ou <a
149 href="programs/dbmmanage.html">dbmmanage</a> (qui sont écrits en
150 Perl) nécessitent l'interpréteur Perl 5 (version 5.003 ou supérieure).
151 Au cas où le script <code>configure</code> ne trouve pas d'interpréteur
152 Perl, la compilation sera quand même réalisée sans souci. Seuls ces
153 scripts ne seront pas utilisables. Si plusieurs interpréteurs Perl sont
154 installés (par exemple, Perl 4 fourni avec l'OS, et Perl 5 installé par
155 l'administrateur), il est conseillé de passer l'option
156 <code>--with-perl</code> afin de garantir que le bon interpréteur est
157 utilisé par <code>./configure</code>.</dd>
161 <section id="download"><title>Télécharger</title>
163 <p>Apache est téléchargeable depuis le <a
164 href="http://httpd.apache.org/download.cgi">site de téléchargement
165 d'Apache</a> qui fournit la liste de plusieurs miroirs. Là sont disponibles
166 les dernières versions. La plupart des
167 utilisateurs d'Apache sur des systèmes de type Unix devraient
168 probablement télécharger et compiler une version à partir du code source.
169 Le processus de construction (décrit ci-dessous) est facile et
170 vous permet d'adapter votre serveur pour convenir à vos besoins.
171 En outre, les versions binaires ne sont souvent pas à jour avec
172 les dernières versions du code source. Si vous téléchargez une
173 version binaire, suivez les instructions dans le dossier
174 <code>INSTALL.bindist</code> à l'intérieur de la distribution.</p>
176 <p>Après le téléchargement, il est important de vérifier que les sources
177 téléchargées sont bien complètes et non modifiées, et ce surtout si un
178 miroir a été utilisé pour le téléchargement. Ceci peut être fait en
179 testant l'archive tar téléchargée avec la signature PGP. Cette procédure
180 s'effectue en 2 étapes. D'abord, il faut récupérer le fichier <a
181 href="http://www.apache.org/dist/httpd/KEYS"><code>KEYS</code></a> du site
182 de distribution d'Apache. (Pour vérifier que ce fichier <code>KEYS</code>
183 n'a pas été modifié, une bonne idée peut être d'utiliser un fichier d'une
184 distribution précédente d'Apache ou d'importer les clés d'un serveur de
185 clés public.) Les clés peuvent être importées dans le keyring de
186 l'utilisateur au moyen d'une des commandes (selon la version de PGP):</p>
188 <example>$ pgp < KEYS</example>
192 <example>$ gpg --import KEYS</example>
194 <p>La prochaine étape est de tester l'archive tar au moyen de la signature
195 PGP, qui devrait toujours être disponible sur le <a
196 href="http://httpd.apache.org/download.cgi">site principal d'Apache</a>.
197 Un lien vers cette signature est placé derrière le lien de téléchargement
198 correspondant ou peut être trouvé dans le répertoire correspondant sur <a
199 href="http://www.apache.org/dist/httpd/">le site de distribution
200 d'Apache</a>. Le nom de ce fichier est le même que celui de l'archive
201 source, avec en plus l'extension <code>.asc</code>. La distribution
202 téléchargée peut alors être vérifiée au moyen de la commande (à nouveau,
203 selon la version de PGP):</p>
205 <example>$ pgp httpd-2_1_<em>NN</em>.tar.gz.asc</example>
209 <example>$ gpg --verify httpd-2_1_<em>NN</em>.tar.gz.asc</example>
211 <p>Un message comme celui-ci devrait s'afficher</p>
213 <example>Good signature from user "Martin Kraemer
214 <martin@apache.org>".</example>
216 <p>Selon les relations de confiances contenues dans le keyring de
217 l'utilisateur, un message peut s'afficher, spécifiant que la relation entre
218 la clé et le signataire ne peut être vérifiée. Ceci n'est pas un problème si
219 vous ne mettez pas en doute l'authenticité du fichier <code>KEYS</code>.</p>
222 <section id="extract"><title>Extraire</title>
224 <p>Extraire les sources à partir de l'archive tar est une simple affaire de
225 décompression et d'extraction tar:</p>
228 $ gzip -d httpd-2_1_<em>NN</em>.tar.gz<br />
229 $ tar xvf httpd-2_1_<em>NN</em>.tar
232 <p>Un nouveau répertoire est créé dans le répertoire courant, il contient le
233 code source de la distribution. Il faut aller dans ce répertoire au moyen
234 de la commande <code>cd</code> avant de commencer la compilation du
238 <section id="configure"><title>Configurer l'arborescence source</title>
240 <p>L'étape suivante est la configuration de l'arborescence source d'Apache,
241 pour votre plate-forme et selon les nécessités du site. Cette configuration est
242 réalisée au moyen du script <code>configure</code> fourni dans le
243 répertoire racine de la distribution. (Les développeurs qui téléchargent
244 Apache via CVS devront utiliser les outils <code>autoconf</code> et
245 <code>libtool</code> avant de passer à la suite. Ceci n'est pas nécessaire
246 pour les versions officielles.)</p>
248 <p>Pour configurer l'arborescence source en utilisant les options par
249 défaut, tapez <code>./configure</code>. Pour modifier les valeurs des
250 options par défaut, <code>configure</code> accepte un grand nombre de
251 variables et d'options de ligne de commande. </p>
253 <p>La plus importante de ces options est le chemin du répertoire où
254 Apache sera installé,
255 car Apache doit être configuré pour que cet emplacement fonctionne
256 correctement. Plusieurs autres options sont disponibles pour
257 le contrôle fin de l'emplacement des fichiers résultants avec <a
258 href="programs/configure.html#installationdirectories">options de
259 configuration</a>.</p>
261 <p>En outre, à ce moment, vous pouvez indiquer quels <a
262 href="programs/configure.html#optionalfeatures">fonctionnalités</a>
263 vous voulez inclure dans Apache en ajoutant et/ou en retranchant
264 des <a href="mod/">modules</a>. Apache vient avec un ensemble
265 de modules de <a href="mod/module-dict.html#Status">Base</a>
266 inclus par défaut. D'autres modules peuvent être ajoutés en utilisant
267 l'option <code>--enable-<var>module</var></code>, où
268 <var>module</var> est le nom du module avec la chaîne
269 <code>mod_</code> coupée et avec les caractères de soulignement
270 convertis en tirets. Vous pouvez également choisir de compiler
271 des modules en tant qu'<a href="dso.html">objets partagés (DSOs)</a>,
272 qui peuvent être chargés ou déchargé à l'exécution -- en employant
273 l'option <code>--enable-<var>module</var>=shared</code>.
274 De même, vous pouvez retrancher les modules de Base avec l'option
275 <code>--disable-<var>module</var></code>. Prenez garde lorsque
276 vous employez ces options, puisque <code>configure</code> ne peut
277 vous informer si le module cible n'existe pas; <code>configure</code>
278 ignorera simplement l'option.</p>
280 <p>Il est parfois nécessaire de fournir des
281 informations supplémentaires au script
282 <code>configure</code> sur l'emplacement de vos
283 compilateur, bibliothèques ou dossiers d'en-tête. Ceci se fait en
284 passant les variables d'environnement ou des options incluses sur la ligne
285 de commande à <code>configure</code>. Pour plus d'information
286 sur ce sujet, consultez la page de documentation
287 <a href="programs/configure.html">configurer</a>.</p>
289 <p>L'exemple suivant compile Apache pour être installé
290 dans <code>/sw/pkg/apache</code> avec un
291 compilateur et des options de compilation particulières, ainsi que les deux
292 modules <module>mod_rewrite</module> et <module>mod_speling</module>, qui
293 pourront être chargés plus tard au moyen des mécanismes DSO:</p>
296 $ CC="pgcc" CFLAGS="-O2" \<br />
297 ./configure --prefix=/sw/pkg/apache \<br />
298 --enable-rewrite=shared \<br />
299 --enable-speling=shared
302 <p>Une fois lancé, <code>configure</code> peut prendre quelques minutes
303 pour tester les possibilités du système et produire les fichiers
304 <code>Makefile</code> qui seront utilisés pour construire le serveur.</p>
306 <p>Les détails de toutes les options <code>configure</code> sont
307 disponibles sur la page de documentation <a href="programs/configure.html">configurer</a>.</p>
310 <section id="compile"><title>Compiler</title>
312 <p>Les différents composants d'Apache sont à présent prêts à
313 être compilés, en tapant simplement la commande:</p>
315 <example>$ make</example>
317 <p>Un peu de patience est requise, une configuration standard met environ 3
318 minutes à compiler sur un Pentium III sous Linux 2.2. Ce temps peut
319 varier largement suivant le matériel utilisé et les modules
320 selectionnés.</p>
323 <section id="install"><title>Installer</title>
325 <p>Il est temps d'installer le 'package' dans le répertoire d'installation
326 <em>PREFIX</em> configuré auparavant (voir l'option <code>--prefix</code>
327 ci-dessus) en tapant:</p>
329 <example>$ make install</example>
331 <p>En cas de mise à jour, l'installation n'écrasera ni les fichiers de
332 configuration du serveur, ni ses documents.</p>
335 <section id="customize"><title>Personnaliser la Configuration</title>
337 <p>Il reste à présent à configurer le serveur HTTP Apache, en éditant les
338 <a href="configuring.html">fichiers de configuration</a> placés dans
339 <code><em>PREFIX</em>/conf/</code>.</p>
341 <example>$ vi <em>PREFIX</em>/conf/httpd.conf</example>
343 <p>A consulter : le manuel d'Apache dans
344 <a href="./">docs/manual/</a> ou bien <a
345 href="http://httpd.apache.org/docs-2.1/"
346 >http://httpd.apache.org/docs-2.1/</a> pour la dernière version de ce
347 manuel, ainsi qu'une référence complète de toutes les
348 <a href="mod/directives.html">directives de configuration</a>.</p>
351 <section id="test"><title>Tester</title>
353 <p>Une fois configuré, le serveur HTTP Apache peut être
354 <a href="invoking.html">démarré</a> en tapant:</p>
356 <example>$ <em>PREFIX</em>/bin/apachectl start</example>
358 <p>Vous devriez alors pouvoir tester l'URL <code>http://localhost/</code>.
359 La page affichée se trouve dans le répertoire
360 <directive module="core">DocumentRoot</directive>, habituellement configuré
361 en tant que <code><em>PREFIX</em>/htdocs/</code>.
362 Le serveur peut être <a href="stopping.html">arrêté</a> en tapant:</p>
364 <example>$ <em>PREFIX</em>/bin/apachectl stop</example>
367 <section id="upgrading"><title>Mise à niveau</title>
369 <p>La première étape pour une mise à niveau est de lire
370 l'annonce de la nouvelle version et le fichier <code>CHANGES</code>
371 dans la distribution afin de trouver tous les changements qui
372 peuvent affecter votre site. Si la mise à jour est effectuée
373 entre deux versions principales (par exemple, de 1.3 à 2.0 ou
374 de 2.0 à 2.2), attendez-vous à des différences majeures
375 au moment de la compilation et de l'exécution, exigeant probablement
376 des ajustements manuels. Tous les modules devront également
377 être mis à niveau pour tenir compte des changements de l'API.</p>
379 <p>La mise à niveau d'une version mineure à une plus récente
380 (par exemple, de 2.0.55 à 2.0.57) est plus facile. Le processus
381 <code>make install</code> n'écrasera aucun de vos documents,
382 fichiers journaux, ou fichiers de configuration existants.
383 En outre, les développeurs font tous les efforts possibles
384 pour éviter les changements incompatibles des options
385 <code>configure</code>, de la configuration d'exécution,
386 ou de l'API entre les versions mineures. Dans la plupart
387 des cas vous devriez pouvoir employer une ligne de commande
388 <code>configure</code> et un fichier de configuration
389 identiques. De plus, tous vos modules devraient continuer à fonctionner.
390 (Ceci ne vaut que pour les versions postérieures à 2.0.41;
391 les versions antérieures ont des changements incompatibles.)</p>
393 <p>Si vous avez gardé l'arborescence source de votre dernière
394 installation, la mise à niveau est encore plus facile.
395 Le dossier <code>config.nice</code> dans la racine de l'ancienne
396 arborescence contient la ligne de commande <code>configure</code>
397 exacte que vous avez utilisée pour configurer l'arborescence des
398 sources. Pour faire la mise à niveau d'une version à la suivante,
399 vous devez copier le dossier <code>config.nice</code> dans
400 l'arborescence des sources de la nouvelle version, l'éditer
401 pour faire les changements désirés, puis exécuter:</p>
404 $ ./config.nice<br />
407 $ <em>PREFIX</em>/bin/apachectl stop<br />
408 $ <em>PREFIX</em>/bin/apachectl start<br />
411 <note type="warning">Vous devriez toujours essayer une
412 nouvelle version dans un environnement de test avant de la
413 mettre dans un environnement de production. Par exemple, vous pouvez
414 installer et exécuter la nouvelle version côte à côte avec l'ancienne
415 en employant un <code>--prefix</code> et un port différents
416 (ce qui est possible en ajustant la directive <directive module="mpm_common">Listen</directive>)
417 dans le but de tester toutes les incompatibilités possibles avant de
418 faire la mise à niveau finale.</note>