KGRKJGETMRETU895U-589TY5MIGM5JGB5SDFESFREWTGR54TY
Server : Apache/2.2.17 (Unix) mod_ssl/2.2.17 OpenSSL/0.9.8e-fips-rhel5 DAV/2 PHP/5.2.17
System : Linux localhost 2.6.18-419.el5 #1 SMP Fri Feb 24 22:47:42 UTC 2017 x86_64
User : nobody ( 99)
PHP Version : 5.2.17
Disable Function : NONE
Directory :  /proc/21571/root/usr/local/apache/manual/vhosts/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //proc/21571/root/usr/local/apache/manual/vhosts/details.html.fr
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="fr" xml:lang="fr"><head><!--
        XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
              This file is generated from xml source: DO NOT EDIT
        XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
      -->
<title>Détails sur le fonctionnement des serveurs virtuels - Serveur Apache HTTP</title>
<link href="../style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
<link href="../style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
<link href="../style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" />
<link href="../images/favicon.ico" rel="shortcut icon" /></head>
<body id="manual-page"><div id="page-header">
<p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/directives.html">Directives</a> | <a href="../faq/">FAQ</a> | <a href="../glossary.html">Glossaire</a> | <a href="../sitemap.html">Plan du site</a></p>
<p class="apache">Serveur Apache HTTP Version 2.2</p>
<img alt="" src="../images/feather.gif" /></div>
<div class="up"><a href="./"><img title="&lt;-" alt="&lt;-" src="../images/left.gif" /></a></div>
<div id="path">
<a href="http://www.apache.org/">Apache</a> &gt; <a href="http://httpd.apache.org/">Serveur HTTP</a> &gt; <a href="http://httpd.apache.org/docs/">Documentation</a> &gt; <a href="../">Version 2.2</a> &gt; <a href="./">Serveurs virtuels</a></div><div id="page-content"><div id="preamble"><h1>Détails sur le fonctionnement des serveurs virtuels</h1>
<div class="toplang">
<p><span>Langues Disponibles: </span><a href="../en/vhosts/details.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
<a href="../fr/vhosts/details.html" title="Français">&nbsp;fr&nbsp;</a> |
<a href="../ko/vhosts/details.html" hreflang="ko" rel="alternate" title="Korean">&nbsp;ko&nbsp;</a> |
<a href="../tr/vhosts/details.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
</div>
<div class="outofdate">Cette traduction peut être périmée. Vérifiez la version
            anglaise pour les changements récents.</div>


    <p>Le code gérant les serveurs virtuels a été réécrit à partir de 
    zéro dans <strong>Apache 1.3</strong>. Ce document vise à expliquer 
    dans le détail comment Apache procède lors du choix de l'utilisation 
    d'un serveur virtuel en fonction d'une requête reçue. L'apparition 
    de la directive  <code class="directive"><a href="../mod/core.html#namevirtualhost">NameVirtualHost</a></code> 
    a rendu beaucoup plus facile et plus sûre la configuration des 
    serveurs virtuels par rapport aux versions précédant la 1.3.</p>

    <p>Si vous voulez juste <cite>que ça marche</cite> sans en 
    comprendre le fonctionnement, voici <a href="examples.html">quelques 
    exemples</a>.</p>

</div>
<div id="quickview"><ul id="toc"><li><img alt="" src="../images/down.gif" /> <a href="#configparsing">Interprétation des fichiers 
de configuration</a></li>
<li><img alt="" src="../images/down.gif" /> <a href="#hostmatching">Choix du serveur virtuel</a></li>
<li><img alt="" src="../images/down.gif" /> <a href="#tips">Trucs et astuces</a></li>
</ul></div>
<div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
<div class="section">
<h2><a name="configparsing" id="configparsing">Interprétation des fichiers 
de configuration</a></h2>

    <p>Un <em>serveur  principal (main_server)</em> contient toutes 
    les définitions qui apparaissent en dehors des sections 
    <code>&lt;VirtualHost&gt;</code>. Les serveurs virtuels, aussi 
    appelés <em>vhosts</em> (pour virtual hosts), sont définis par les 
    sections <code class="directive"><a href="../mod/core.html#virtualhost">&lt;VirtualHost&gt;</a></code>.</p>

    <p>Les directives
    <code class="directive"><a href="../mod/mpm_common.html#listen">Listen</a></code>,
    <code class="directive"><a href="../mod/core.html#servername">ServerName</a></code>,
    <code class="directive"><a href="../mod/core.html#serverpath">ServerPath</a></code>,
    et <code class="directive"><a href="../mod/core.html#serveralias">ServerAlias</a></code>
    peuvent être placées n'importe où dans le cadre de définition d'un
    serveur. Cependant, chaque fois que l'une d'elles est lue, elle écrase 
    ses instances précédentes (dans le contexte du même serveur).</p>

    <p>La valeur par défaut du champ <code>Listen</code> pour le serveur 
    principal est de 80. Le serveur principal n'a pas de valeur par 
    défaut pour <code>ServerPath</code> ni pour <code>ServerAlias</code>. 
    La valeur par défaut de <code>ServerName</code> est déduite à partir 
    de l'adresses IP du serveur.</p>

    <p>La directive Listen associée au serveur principal a deux utilités. 
    La première détermine le port réseau sur lequel Apache va écouter. 
    La deuxième spécifie le port qui sera utilisé dans les URIs absolus 
    lors des redirections.</p>

    <p>À la différence du serveur principal, les ports des serveurs 
    virtuels <em>n</em>'affectent <em>pas</em> les ports sur lesquels 
    Apache se met à l'écoute.</p>

    <p>Chaque adresse incluse dans une directive <code>VirtualHost</code> 
    peut disposer d'un port optionnel. Si le port n'est pas précisé, il 
    prend par défaut la dernière valeur de <code>Listen</code> lue dans 
    la configuration du serveur principal. Le port particulier 
    <code>*</code> représente un joker qui correspond à tous les ports. 
    L'ensemble des adresses (y compris les résultats multiples 
    <code>A</code> issus des requêtes DNS) est appelé <em>jeu 
    d'adresses</em> du serveur virtuel.</p>

    <p>À moins qu'une directive 
    <code class="directive"><a href="../mod/core.html#namevirtualhost">NameVirtualHost</a></code> ne soit utilisée 
    pour une adresse IP spécifique, le premier serveur virtuel avec 
    cette adresse est considéré comme un <em>serveur virtuel par-IP</em>. 
    L'adresse IP peut également prendre la valeur joker <code>*</code>.</p>

    <p>Dans les cas où l'on souhaite utiliser un <em>serveur virtuel 
    par nom</em>, la directive <code>NameVirtualHost</code> <em>doit</em> 
    apparaître avec l'adresse IP choisie. En d'autres termes, vous devez 
    spécifier dans votre fichier de configuration l'adresse IP des noms 
    de domaine (CNAME) de vos serveurs virtuels par nom au moyen de 
    la directive <code>NameVirtualHost</code>.</p>

    <p>On peut utiliser plusieurs directives <code>NameVirtualHost</code> 
    pour un groupe de directives <code>VirtualHost</code>, mais seule 
    une directive <code>NameVirtualHost</code> doit être utilisée pour 
    chaque couple IP:port donné.</p>

    <p>L'ordre d'apparition des directives <code>NameVirtualHost</code> 
    et <code>VirtualHost</code> est sans importance, ce qui fait que 
    les deux exemples suivants ont des effets identiques (seul l'ordre 
    des directives <code>VirtualHost</code> pour <em>un</em> jeu 
    d'adresses est important, voir ci-dessous)&nbsp;:</p>

<table><tr>
<td><div class="example"><p><code>
  NameVirtualHost 111.22.33.44<br />
  &lt;VirtualHost 111.22.33.44&gt;<br />
  # serveur A<br />
  ...<br />
  &lt;/VirtualHost&gt;<br />
  &lt;VirtualHost 111.22.33.44&gt;<br />
  # serveur B<br />
  ...<br />
  &lt;/VirtualHost&gt;<br />
  <br />
  NameVirtualHost 111.22.33.55<br />
  &lt;VirtualHost 111.22.33.55&gt;<br />
  # serveur C<br />
  ...<br />
  &lt;/VirtualHost&gt;<br />
  &lt;VirtualHost 111.22.33.55&gt;<br />
  # serveur D<br />
  ...<br />
  &lt;/VirtualHost&gt;
</code></p></div></td>
<td><div class="example"><p><code>
  &lt;VirtualHost 111.22.33.44&gt;<br />
  # serveur A<br />
  &lt;/VirtualHost&gt;<br />
  &lt;VirtualHost 111.22.33.55&gt;<br />
  # serveur C<br />
  ...<br />
  &lt;/VirtualHost&gt;<br />
  &lt;VirtualHost 111.22.33.44&gt;<br />
  # serveur B<br />
  ...<br />
  &lt;/VirtualHost&gt;<br />
  &lt;VirtualHost 111.22.33.55&gt;<br />
  # serveur D<br />
  ...<br />
  &lt;/VirtualHost&gt;<br />
  <br />
  NameVirtualHost 111.22.33.44<br />
  NameVirtualHost 111.22.33.55<br />
  <br />
</code></p></div></td>
</tr></table>


    <p>(Il est conseillé d'adopter le choix de gauche pour faciliter 
    la lisibilité des fichiers de configuration.)</p>

    <p>Après la lecture de la directive <code>VirtualHost</code>, le 
    serveur virtuel se voit attribuer une valeur <code>Listen</code> 
    par défaut qui est la valeur du port associé au premier nom spécifié 
    dans sa directive <code>VirtualHost</code>.</p>

    <p>La liste complète des noms d'une directive <code>VirtualHost</code> 
    est gérée exactement comme des <code>ServerAlias</code> (mais ne 
    sont pas écrasés par d'autres <code>ServerAlias</code>) si tous 
    les noms sont résolus dans ce jeu d'adresse. À noter que les états 
    <code>Listen</code> de ce serveur virtuel sont sans incidence sur 
    les ports attibués au jeu d'adresses.</p>

    <p>Pendant la phase d'initialisation, une liste de chaque adresse 
    IP est générée et introduite dans une table de 'hash'. Si une 
    adresse IP est utilisée dans une directive <code>NameVirtualHost</code>, 
    cette liste contient les noms des serveurs virtuels pour cette 
    adresse. Si aucun serveur virtuel n'est défini pour cette adresse, 
    la directive <code>NameVirtualHost</code> est ignorée et un message 
    est envoyé au journal d'erreurs. Quand un serveur virtuel par IP 
    est utilisé, la table de 'hash' reste vide.</p>

    <p>La fonction de 'hash' étant rapide, le temps d'exécution d'un 
    'hash' sur une adresse IP lors d'une requête est minimale et 
    quasiment imperceptible. De plus, la table est optimisée pour les 
    adresses IP dont le dernier octet est le seul à changer.</p>

    <p>Pour chaque serveur virtuel, diverses valeurs sont initialisées 
    par défaut. En particulier&nbsp;:</p>

    <ol>
      <li>Dans le cas où un serveur virtuel ne contient pas de directives 
      <code class="directive"><a href="../mod/core.html#serveradmin">ServerAdmin</a></code>,
      <code class="directive"><a href="../mod/core.html#resourceconfig">ResourceConfig</a></code>,
      <code class="directive"><a href="../mod/core.html#accessconfig">AccessConfig</a></code>,
      <code class="directive"><a href="../mod/core.html#timeout">Timeout</a></code>,
      <code class="directive"><a href="../mod/core.html#keepalivetimeout">KeepAliveTimeout</a></code>,
      <code class="directive"><a href="../mod/core.html#keepalive">KeepAlive</a></code>,
      <code class="directive"><a href="../mod/core.html#maxkeepaliverequests">MaxKeepAliveRequests</a></code>,
      ou <code class="directive"><a href="../mod/core.html#sendbuffersize">SendBufferSize</a></code>,
      alors la valeur de chacun de ces paramètres est héritée de celle du
      serveur principal. (C'est à dire, héritée de la valeur finale après
      lecture de la configuration du serveur principal.)</li>

      <li>Les permissions par défaut sur les répertoires de chaque 
      serveur virtuel sont assemblées avec celles du serveur principal. 
      Elles concernent également toutes les informations de configuration 
      par répertoire pour tous les modules.</li>

      <li>Les configurations par serveur pour chaque module sont assemblées 
      à partir de celles du serveur principal.</li>
    </ol>

    <p>L'essentiel des valeurs de configuration des serveurs virtuels 
    provient de valeurs par défaut issues du serveur principal.
    Mais la position dans le fichier de configuration des directives
    du serveur principal n'a pas d'importance -- l'ensemble de la 
    configuration du serveur principal est lu avant que ces valeurs par 
    défaut soient appliquées aux serveur virtuels. Ainsi, même si la 
    définition d'une valeur apparaît après celle d'un serveur virtuel, 
    cette valeur peut affecter la definition du serveur virtuel.</p>

    <p>Dans le cas où le serveur principal n'a pas de <code>ServerName</code> 
    à ce stade, le nom de la machine sur laquelle tourne le programme 
    <code class="program"><a href="../programs/httpd.html">httpd</a></code> est utilisé à sa place. Nous appellerons 
    <em>jeu d'adresses du serveur principal</em>, les adresses IP 
    renvoyées par une résolution DNS sur le <code>ServerName</code> 
    du serveur principal.</p>

    <p>Pour tous les champs <code>ServerName</code> non définis, dans 
    le cas d'une configuration en serveur virtuel par nom, la valeur 
    adoptée par défaut est la première adresse donnée dans la section 
    <code>VirtualHost</code> qui définit le serveur virtuel.</p>

    <p>Si un serveur virtuel contient la valeur magique 
    <code>_default_</code>, il fonctionne sur le même <code>ServerName</code> 
    que le serveur principal.</p>

</div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
<div class="section">
<h2><a name="hostmatching" id="hostmatching">Choix du serveur virtuel</a></h2>

    <p>À la réception d'une requête, le serveur procède comme suit pour
    déterminer quel serveur virtuel utiliser&nbsp;:</p>

    <h3><a name="hashtable" id="hashtable">Vérification dans la table de hash</a></h3>

    <p>Après que le client se soit connecté, l'adresse 
    IP à laquelle le client s'est connecté est recherchée dans la 
    table de hash IP interne.</p>

    <p>Si la résolution de l'adresse IP n'aboutit pas (adresse IP non 
    trouvée), la requête est servie par le serveur virtuel 
    <code>_default_</code> s'il est défini pour le port correspondant 
    à la requête. Sinon, elle est servie par le serveur principal.</p>

    <p>Si l'adresse IP n'est pas trouvée dans la table de hash, la 
    recherche du numéro de port peut aussi se terminer par une 
    correspondance à un <code>NameVirtualHost *</code> qui est géré 
    ensuite comme les autres serveur virtuels par noms.</p>
    
    <p>Si une liste est bien trouvée dans la table pour l'adresse 
    IP recherchée, l'étape suivante est de déterminer s'il s'agit 
    d'un serveur virtuel par nom ou par IP.</p>

    

    <h3><a name="ipbased" id="ipbased">Serveur virtuel par IP</a></h3>

    <p>Si l'entrée trouvée dispose d'une liste de noms vide, c'est 
    qu'il s'agit d'un serveur virtuel par IP, et aucun autre choix 
    n'est plus à faire&nbsp;; la requête est servie par ce serveur virtuel.</p>

    

    <h3><a name="namebased" id="namebased">Serveur virtuel par nom</a></h3>

    <p>Si l'entrée trouvée correspond à un serveur virtuel par nom, 
    la liste de noms contient au moins une structure de serveurs 
    virtuels. Les serveurs virtuels se présentent dans cette liste 
    dans le même ordre que la lecture des directives <code>VirtualHost</code> 
    dans le fichier de configuration.</p>

    <p>Le premier serveur virtuel de cette liste (donc, le premier 
    serveur virtuel attribué à une adresse IP donnée dans le fichier 
    de configuration) se voit attribuer la plus grande priorité, ce 
    qui signifie que c'est lui qui traite les requêtes présentant un 
    nom de serveur invalide ou ne présentant pas de champ 
    <code>Host:</code> dans l'en-tête.</p>

    <p>Si un champ <code>Host:</code> est transmis dans l'en-tête de 
    la requête, son occurrence est recherchée dans la liste et le 
    premier serveur virtuel qui présente un <code>ServerName</code> 
    ou un <code>ServerAlias</code> correspondant est choisi pour 
    servir la requête. Il est possible que le champ <code>Host:</code> 
    contienne un numéro de port, mais Apache utilise toujours le 
    port sur lequel il a effectivement reçu la requête.</p>

    <p>Dans le cas où le client a envoyé une requête en HTTP/1.0 sans 
    un champ d'en-tête <code>Host:</code>, il est impossible de 
    déterminer le serveur auquel le client veut se connecter&nbsp;; l'URI 
    de la requête est recherché dans tous les <code>ServerPath</code> 
    existants. Le premier chemin trouvé est utilisé et la requête est 
    servie par le serveur virtuel correspondant.</p>

    <p>Si aucun serveur virtuel n'est trouvé, la requête est servie 
    par le premier serveur virtuel qui écoute sur le port demandé et 
    qui est sur la liste associée à l'adresse IP vers laquelle la 
    requête a été envoyée (comme déjà précisé ci-avant).</p>

    

    <h3><a name="persistent" id="persistent">Connexions persistantes</a></h3>

    <p>La recherche par adresse IP décrite ci-avant n'est faite 
    qu'<em>une fois</em> pour chaque session TCP/IP, alors que la 
    recherche par nom est réalisée pour <em>chaque</em> requête au 
    cours d'une connexion persistante (KeepAlive). En d'autres termes, 
    il est possible pour un client de faire des requêtes sur 
    différents serveurs virtuels par nom, au cours d'une unique 
    connexion persistante.</p>

    

    <h3><a name="absoluteURI" id="absoluteURI">URI absolu</a></h3>

    <p>Au cas où l'URI de la requête est absolu, et que son nom de 
    serveur et son port correspondent au serveur principal (ou l'un 
    des serveurs virtuels configurés), <em>et</em> qu'ils correspondent 
    à l'adresse et au port de la requête, alors l'URI est amputé 
    de son préfixe protocole/nom de serveur/port et traité par le 
    serveur correspondant (principal ou virtuel). Si cette correspondance 
    n'existe pas, l'URI reste inchangé et la requête est considérée 
    comme une requête d'un serveur mandataire (proxy).</p>


<h3><a name="observations" id="observations">Observations</a></h3>

    <ul>
      <li>Les serveurs virtuels par nom et par IP n'interfèrent 
      jamais entre eux. Les serveurs virtuels par IP ne sont joignables 
      qu'au travers de leur(s) adresse(s) IP propre(s), en aucun 
      cas par aucune autre adresse. Les serveurs virtuels par nom 
      ne sont accessibles que par leur(s) adresse(s) IP qui ne peuvent 
      être définies qu'au moyen de la directive 
      <code>NameVirtualHost</code>.</li>

      <li>Les vérifications sur <code>ServerAlias</code> et 
      <code>ServerPath</code> ne sont jamais réalisées pour les 
      serveurs virtuels par IP.</li>

      <li>L'ordre dans lequel sont agencés dans le fichier de 
      configuration le serveur virtuel <code>_default_</code>, les 
      serveurs virtuels par nom et par IP, et la directive 
      <code>NameVirtualHost</code> est sans incidence sur le 
      fonctionnement. Seul l'ordre des serveurs virtuels par nom 
      pour une adresse donnée a une importance. Le serveur virtuel 
      par nom qui est présent en premier dans la configuration se 
      voit attribué la priorité la plus haute pour les requêtes 
      arrivant sur son jeu d'adresses IP.</li>

      <li>Pour des raisons de sécurité, le numéro de port présenté 
      dans le champ d'en-tête <code>Host:</code> n'est jamais utilisé 
      pour les tests de correspondances. Apache ne prend en compte 
      que le numéro de port sur lequel le client a envoyé la requête.</li>

      <li>Si une directive <code>ServerPath</code> existe, et se 
      trouve être préfixe d'une autre directive <code>ServerPath</code> 
      qui apparaît plus loin dans la configuration, la première 
      sera toujours utilisée et la deuxième jamais. (Ceci ne se 
      produit que dans le cas où aucun champ <code>Host:</code> 
      n'a été présenté par le client pour distinguer les deux.)</li>

      <li>Dans le cas où deux serveurs virtuels par IP ont une 
      adresse en commun, le serveur virtuel qui apparaît en premier 
      dans la configuration est toujours choisi. Ce genre de chose 
      peut arriver par inadvertance. Le serveur envoie une alerte 
      dans le journal d'erreurs si ce cas se présente.</li>

      <li>Le serveur virtuel <code>_default_</code> ne sert la requête 
      que si aucun autre serveur virtuel travaillant sur l'adresse 
      IP <em>et</em> le port demandés n'est trouvé. La requête n'est 
      traitée que si le numéro de port qui a reçu la requête est 
      associé au serveur virtuel <code>_default_</code> (qui par 
      défaut, correspond à <code>Listen</code>). Un port joker peut 
      être spécifié (<em>comme dans</em> <code>_default_:*</code>) 
      pour récupérer les requêtes sur tous les ports ouverts. Ceci 
      est également applicable aux serveurs virtuels 
      <code>NameVirtualHost *</code>.</li>

      <li>Le serveur principal ne sert à servir les requêtes que 
      lorsque l'adresse IP et le port demandés par le client ne 
      correspondent à aucun serveur virtuel (y compris un serveur 
      virtuel <code>_default_</code>). En d'autres termes, le serveur 
      principal n'est utile que pour les combinaisons adresse/port 
      non spécifiées (sauf quand un serveur virtuel <code>_default_</code> 
      correspond au port).</li>

      <li>Ni les serveurs virtuels <code>_default_</code>, ni le 
      serveur principal ne sont utilisés pour traiter une requête 
      avec un champ d'en-tête <code>Host:</code> manquant ou vide 
      lorsque l'adresse (et le port) de connexion correspondent à 
      des serveurs virtuels par nom, par exemple, dans une directive 
      <code>NameVirtualHost</code>.</li>

      <li>Il ne faut jamais employer de noms DNS dans des directives 
      <code>VirtualHost</code>, car cela oblige le serveur a s'appuyer 
      sur le DNS au moment du démarrage. De plus, vous vous exposez 
      à des problèmes de sécurité si vous n'avez pas la maîtrise du 
      DNS pour la totalité de vos domaines. Voir la documentation 
      <a href="../dns-caveats.html">disponible ici</a>, ainsi que 
      les deux points précisés ci-après.</li>

      <li>Un nom de serveur <code>ServerName</code> devrait toujours 
      être indiqué pour chaque serveur virtuel. Sans cela, une 
      résolution DNS est nécessaire pour chaque serveur virtuel.</li>
      </ul>
      

</div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
<div class="section">
<h2><a name="tips" id="tips">Trucs et astuces</a></h2>

    <p>En plus des points évoqués sur la page des 
    <a href="../dns-caveats.html#tips">problèmes liés au DNS</a>, 
    voici quelques points intéressants&nbsp;:</p>

    <ul>
      <li>Toujours positionner les définitions relatives au serveur 
      principal avant toute définition <code>VirtualHost</code>. 
      (Ceci améliore grandement la lisibilité de la configuration 
      -- la manière dont la configuration est interprétée après la 
      lecture des fichiers ne met pas en évidence le fait que les 
      définitions positionnées avant et surtout après les serveurs 
      virtuels peuvent impacter le fonctionnement des serveurs virtuels.)</li>

      <li>Toujours regrouper les définitions <code>NameVirtualHost</code> 
      et <code>VirtualHost</code> dans la configuration pour une 
      meilleure lisibilité.</li>

      <li>Éviter les <code>ServerPaths</code> qui sont préfixes 
      d'autres <code>ServerPaths</code>. Si cela ne peut être évité, 
      veillez à ce que le serveur virtuel contenant le préfixe le plus 
      long (donc le plus précis) apparaisse dans le fichier de 
      configuration avant le plus court. (<em>par exemple</em>, 
      "ServerPath /abc" est à spécifier après  "ServerPath /abc/def").</li>
    </ul>

</div></div>
<div class="bottomlang">
<p><span>Langues Disponibles: </span><a href="../en/vhosts/details.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
<a href="../fr/vhosts/details.html" title="Français">&nbsp;fr&nbsp;</a> |
<a href="../ko/vhosts/details.html" hreflang="ko" rel="alternate" title="Korean">&nbsp;ko&nbsp;</a> |
<a href="../tr/vhosts/details.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
</div><div id="footer">
<p class="apache">Copyright 2009 The Apache Software Foundation.<br />Autorisé sous <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p>
<p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/directives.html">Directives</a> | <a href="../faq/">FAQ</a> | <a href="../glossary.html">Glossaire</a> | <a href="../sitemap.html">Plan du site</a></p></div>
</body></html>

Anon7 - 2021