logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Ceci est une ancienne révision du document !


apache2 : serveur Web multi-site

Préambule et pré-requis

Ce bref tutorial a deux objectifs :

  1. Me servir de pense bête ! (et vous en faire profiter) :-P
  2. Expliquer comment mettre en œuvre la gestion multisite d'Apache2

Tout est parti du besoin que j'ai eu de devoir tester des outils de “création de site” au sein de l'intranet de mon travail.

Il me fallait donc un serveur Apache2 et la possibilité de tester plusieurs sites, un par outil (Divers CMS, Divers Wiki… ). Le tout en local.

Or, un coup de Google m'a montré beaucoup des liens dans la langue de Shakespeare, mais bien peu dans celle de Molière et en tous les cas rien qui m'ait beaucoup avancé.

Je vais donc, avec ce tutoriel, essayer de vous (me) faire gagner du temps.

“hère we Go…”

Pré-requis

  • Un serveur Apache 2 (+/- PHP, MySQL suivant le type de site à réaliser)
Pour ceux n'ayant pas de serveur LAMP installé : <code root>apt-get install apache2 mysql-server libapache2-mod-php5 php5-mysql</code> Et voilà.</note> * Au moins 2 sites a tester ! ===== Déclaration des sites existants===== Dans Apache2, les sites disponibles (on parle de virtualhosts, ou vhost) sont déclarés à l'aide de fichier dans le répertoire : /etc/apache2/sites-avalaible/ Partons du principe que vous souhaitez mettre en ligne 2 sites que nous nommerons site-1 et site-2 (pourquoi faire compliqué ? 8-))
Apache vous livre lors de son installation dans ce même répertoire un fichier “default” qui va nous servir de base pour nos 2 sites
On va donc en faire une copie : <code root> cp /etc/apache2/sites-avalaible/default /etc/apache2/sites-avalaible/site-1 cp /etc/apache2/sites-avalaible/default /etc/apache2/sites-avalaible/site-2 </code> ==== Contenu du fichier de vhost ==== Dans votre éditeur de texte favori (pas un traitement texte attention !) ouvrez le fichier site-1
Faisons un rapide tour d'horizons des sections qui nous intéressent: <code xml><VirtualHost *:80> ServerAdmin webmaster@localhost DocumentRoot /var/www <Directory /> Options FollowSymLinks AllowOverride None </Directory> <Directory /var/www/> Options Indexes FollowSymLinks MultiViews AllowOverride None Order allow,deny allow from all </Directory> ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/ <Directory “/usr/lib/cgi-bin”> AllowOverride None Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch Order allow,deny Allow from all </Directory> ErrorLog ${APACHE_LOG_DIR}/error.log # Possible values include: debug, info, notice, warn, error, crit, # alert, emerg. LogLevel warn CustomLog ${APACHE_LOG_DIR}/access.log combined Alias /doc/ “/usr/share/doc/” <Directory “/usr/share/doc/”> Options Indexes MultiViews FollowSymLinks AllowOverride None Order deny,allow Deny from all Allow from 127.0.0.0/255.0.0.0 ::1/128 </Directory> </VirtualHost> </code> * <VirtualHost *:80> et </VirtualHost>: Signalent le début et la fin de la section du vhost, en écoute pour toute les interfaces/adresses IP (*) sur le port
80. * ServerAdmin webmaster@localhost : adresse mail où envoyer les messages d'erreur. Devra donc être remplacée par la vôtre * ServerName www.blablabla.xxx : Nom utilisé par le vhost, remplacez le par le nom de votre site (ici site-1) * ServerAlias site-1.xxx*.site-1.xxx : ServerAlias définie les autres sous domaines pour lesquels le vhost répondra. * DocumentRoot /var/www/htdocs : Répertoire de stockage du site (sa racine). Vous devrez donc modifier cette directive pour qu'elle pointe sur votre racine (ex: /home/www/site-1 ) * DirectoryIndex index.php : En l'absence de page spécifique demandée par l'internaute, c'est cette page que sera affichée, c'est donc en quelque sorte votre page d'accueil. A modifier donc si votre page d'accueil porte un nom différent (default.html, accueil.php, etc.) <note>Voila pour les directives qui nous préoccupent. Comme vous le constatez vous même, il en reste d'autre que je n'ai pas détaillées, mais qui sont importantes notamment pour la sécurité. Je vous invite donc à consulter cette page pour savoir plus : http://doc.ubuntu-fr.org/apache2</note> ==== Fichier vhost adapté ==== Voyons voir a quoi pourrait ressembler notre fichier une fois adapté à nos besoins: <code xml> <VirtualHost *:80> ServerAdmin MonMail@gmail.com ServerName www.site-1.fr ServerAlias site-1.fr ServerAlias *.site-1.fr DocumentRoot /home/www/site-1 DirectoryIndex index.php <Directory /> Options FollowSymLinks AllowOverride None </Directory> <Directory /home/www/site-1> Options Indexes FollowSymLinks MultiViews AllowOverride None Order allow,deny allow from all </Directory> ErrorLog /home/www/apache_log/error_site-1.log # Possible values include: debug, info, notice, warn, error, crit, # alert, emerg. LogLevel warn CustomLog /home/www/apache_log/access_site-1.log combined </VirtualHost> </code> Renouveler les opérations pour créer un fichier de vhost pour site-2 ==== Activation/Désactivation des sites ==== Une fois les fichiers de vhost créés, il reste à les activer pour qu'Apache2 les prenne en compte. Ce mécanisme permet d'avoir tout les fichiers de vhosts que l'on veut et de n'activer que ceux nécessaires. Deux méthodes possible:**
  • Méthode Classique: Création/suppresion d'un lien symbolique dans /etc/apache2/sites-enable pointant vers/etc/apache2/sites-avalaible/site-1
ln -s /etc/apache2/sites-avalaible/site-1 /etc/apache2/sites-enable
  • Méthode Debian : les Développeurs Debian, qui font bien les choses (sinon, ils ne seraient pas DD !), ont mis en place un outil très simple:
a2ensite site-1

…et comme ils ne font pas les choses a moitié, ils ont aussi prévu la désactivation

a2dissite site-1

===== Adaptation du fichier /etc/hosts ===== Éditez votre fichier /etc/hosts et modifiez le comme suit pour que votre machine fasse le rapport entre vos vhost et le localhost.

/etc/hosts
127.0.0.1       localhost
127.0.0.1       site-1
127.0.0.1       site-2

===== Relancer le serveur apache2 et tester===== ==== Relancer apache2 ====

Voir : invoke-rc.d

service apache2 restart

==== Testez vos sites ==== Ouvrez votre navigateur et testez en tapant dans la barre d'adresse:

Vous devriez voir apparaître la page d'accueil des site-1 et site-2.

1)
N'hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !
doc/reseau/apache2/multisite.1404572862.txt.gz · Dernière modification: 05/07/2014 17:07 par captnfab

Pied de page des forums

Propulsé par FluxBB