<-
Apache > Serveur HTTP > Documentation > Version 2.4 > Serveurs virtuels

Détails sur le fonctionnement des serveurs virtuels

Langues Disponibles:  en  |  fr  |  ko  |  tr 

Ce document vise à expliquer dans le détail comment le serveur HTTP Apache procède lors du choix de l'utilisation d'un serveur virtuel en fonction d'une requête reçue.

Il est recommandé de lire la documentation Serveurs virtuels à base de nom et serveurs virtuels à base d'adresse IP pour déterminer quel type de serveur virtuel nous convient le mieux, puis de lire les documentations serveurs virtuels à base de nom ou serveurs virtuels à base d'adresse IP, et enfin d'étudier quelques exemples.

Si vous voulez entrer dans les détails, vous pouvez revenir vers cette page.

Voir aussi

top

Fichier de configuration

Un serveur principal (main_server) contient toutes les définitions qui apparaissent en dehors des sections <VirtualHost>.

Les serveurs virtuels, aussi appelés vhosts (pour virtual hosts), sont définis par les sections <VirtualHost>.

Chaque directive VirtualHost comporte une ou plusieurs adresses et des ports optionnels.

Il est possible d'utiliser des noms d'hôtes dans la définition d'un serveur virtuel, mais ils seront résolus en adresses IP au démarrage du serveur, et si une résolution de nom échoue, cette définition de serveur virtuel sera ignorée. Cette méthode est par conséquent déconseillée.

L'adresse peut être spécifiée sous la forme *, ce qui conviendra à la requête si aucun autre serveur virtuel ne possède l'adresse IP explicite correspondant à celle de la requête.

L'adresse qui apparaît dans la directive VirtualHost peut être associée à un port optionnel. Si aucun port n'est spécifié, il s'agit d'un port générique qui peut aussi être spécifié comme *. Le port générique correspond à toutes les valeurs de port.

(Il ne faut pas confondre les numéros de port sur lesquels Apache est en écoute avec les numéros de port spécifiés dans la directive VirtualHost ; ces derniers ne servent qu'à définir le serveur virtuel qui sera sélectionné pour traiter la requête. Pour définir les ports sur lesquels Apache est en écoute, utilisez la directive Listen).

L'ensemble des adresses (y compris les résultats multiples A issus des requêtes DNS) est appelé jeu d'adresses du serveur virtuel.

Apache fait automatiquement sa sélection à partir de l'en-tête HTTP Host fourni par le client, lorsque la correspondance la plus exacte du point de vue adresse IP/port a lieu pour plusieurs serveurs virtuels.

La directive ServerName peut apparaître en quelque endroit de la définition d'un serveur. Cependant, chaque occurrence écrase la précédente (pour ce serveur). Si aucune directive ServerName n'est spécifiée, le serveur tente de déterminer le nom du serveur à partir de l'adresse IP.

Le premier serveur virtuel à base de nom apparaissant dans le fichier de configuration pour une paire IP:port donnée est significatif car c'est lui qui sera utilisé pour toutes les requêtes reçues sur cette adresse IP/port et pour laquelle aucun autre serveur virtuel ne possède un ServerName ou un ServerAlias correspondant. Il sera aussi utilisé pour toutes les connexions SSL si le serveur ne supporte pas l'Indication du nom du serveur.

Tous les noms spécifiés au sein d'une section VirtualHost sont traités comme un ServerAlias (sans caractères génériques), mais ne sont écrasés par aucune directive ServerAlias.

Pour chaque serveur virtuel, diverses valeurs sont initialisées par défaut. En particulier :

  1. Dans le cas où un serveur virtuel ne contient pas de directives ServerAdmin, Timeout, KeepAliveTimeout, KeepAlive, MaxKeepAliveRequests, ReceiveBufferSize, ou SendBufferSize, 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.)
  2. 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.
  3. Les configurations par serveur pour chaque module sont assemblées à partir de celles du serveur principal.

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.

Dans le cas où le serveur principal n'a pas de ServerName à ce stade, le nom de la machine sur laquelle tourne le programme httpd est utilisé à sa place. Nous appellerons jeu d'adresses du serveur principal les adresses IP renvoyées par une résolution DNS sur le ServerName du serveur principal.

Pour tous les champs ServerName 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 VirtualHost qui définit le serveur virtuel.

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

top

Choix du serveur virtuel

Le serveur détermine le serveur virtuel à utiliser pour une requête en deux phases : une recherche basée sur l’IP lorsque la connexion est établie, puis une recherche optionnelle à base de nom à la réception de la requête.

Phase 1 : recherche sur l’adresse IP et le port

Lorsqu’une connexion est établie, le serveur recherche l’adresse IP et le port de destination dans sa liste d’adresses/ports des serveurs virtuels. Cette recherche respecte un ordre de priorité strict :

PrioritéType de correspondanceExemple
1Adresse IP et port exacts <VirtualHost 10.0.0.1:80>
2Adresse IP exacte, port générique <VirtualHost 10.0.0.1:*>
3Adresse IP générique (*), port exact <VirtualHost *:80>
4Adresse IP et port génériques <VirtualHost *:*>
5Serveur principal (aucun serveur virtuel ne correspond)

Important

Le serveur utilise la première correspondance trouvée en suivant cet ordre. Lorsqu’une correspondance est trouvée à un niveau de priorité donné, aucun niveau de priorité inférieur n’est considéré — même si un serveur virtuel de priorité inférieure possède un ServerName qui correspond au contenu de l’en-tête Host de la requête. La recherche à base de nom (Phase 2) n’intervient que lorsque deux serveurs virtuels de même niveau de priorité peuvent correspondre.

S'il existe des définitions VirtualHost pour l'adresse IP, l'étape suivante consiste à déterminer si nous avons à faire à un serveur virtuel à base de nom ou d'adresse IP.

Serveur virtuel par IP

Si la Phase 1 ne trouve qu’un seul serveur virtuel correspondant, la requête est servie directement depuis ce dernier sans effectuer d’autre recherche.

Phase 2 : recherche à base de nom

Si la phase 1 trouve plusieurs serveurs virtuels correspondants de même niveau de priorité, le serveur effectue une recherche à base de nom parmi ces serveurs virtuels en utilisant l’en-tête Host: de la requête (ou le nom d’hôte SNI pour les connexions SSL).

Si la connexion utilise SSL, si le serveur supporte l'Indication de nom de serveur, et si la négociation du client SSL inclut l'extension TLS dans le nom d'hôte requis, alors ce nom d'hôte sera utilisé par la suite, tout comme un en-tête Host: aurait été utilisé dans le cas d'une connexion non-SSL. Si ces conditions ne sont pas réunies, le premier serveur virtuel à base de nom dont l'adresse correspond sera utilisé pour les connexions SSL. Ceci est important car c'est le serveur virtuel qui détermine quel certificat le serveur va utiliser pour la connexion.

La recherche de serveurs virtuels correspondants s’effectue selon leur ordre d’apparition dans le fichier de configuration :

  1. Les contenus des directives ServerName et ServerAlias de chaque serveur virtuel sont comparés au nom d’hôte de la requête. La première correspondance est retenue.
  2. Si aucun ServerName ou ServerAlias ne correspond, c’est le premier serveur virtuel de la liste qui sera choisi. Il s’agit du serveur virtuel à base de nom par défaut pour cette combinaison adresse/port.

Un champ d’en-tête Host: peut contenir un numéro de port, mais httpd l’ignore toujours et effectue sa recherche de correspondance avec le port réel auquel le client a envoyé sa requête.

Si la requête ne possède pas d’en-tête Host: (comme les requêtes HTTP/1.0), le premier serveur virtuel qui correspond est choisi. Mais si une directive ServerPath est configurée pour un des serveurs virtuels correspondants et que l’URL de la requête correspond à ce chemin, la requête sera servie depuis ce serveur virtuel. Il s’agit d’un mécanisme patrimonial pour les clients HTTP/1.0 ; voir l’exemple avec ServerPath pour les détails.

Connexions persistantes

La recherche par adresse IP (Phase 1) n'est effectuée qu'une fois pour une session TCP/IP particulière, alors que la recherche par nom (Phase 2) est effectuée pour chaque requête au cours d'une connexion persistante (KeepAlive). En d'autres termes, il est possible pour un client de faire des requêtes pour des pages sur différents serveurs virtuels par nom, au cours d'une unique connexion persistante.

URI absolu

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), et 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).

Observations

top

Trucs et astuces

En plus des points évoqués sur la page des problèmes liés au DNS, voici quelques points intéressants :

Langues Disponibles:  en  |  fr  |  ko  |  tr