Archives du blog

Apache 2.4 sous Windows – version 2.4.6 disponible

Depuis le 22 Juillet 2013 la version 2.4.6 d’Apache est disponible.

Les versions 32 bits et 64 bits sont disponibles sur le site Apache lounge :

compilées en VC10 (Visual Studio 2010)
version 32 bits : http://www.apachelounge.com/download/
Pour utiliser cette version vous devez installer Microsoft Visual C++ 2010 SP1 x86

version 64 bits : http://www.apachelounge.com/download/win64/
Pour utiliser cette version vous devez installer Microsoft Visual C++ 2010 SP1 x64

compilées en VC11 (Visual Studio 2012)
version 32 bits : http://www.apachelounge.com/download/VC11/
Pour utiliser cette version vous devez installer la version 32 bits de Visual C++ pour Visual Studio 2012 update 3

version 64 bits : http://www.apachelounge.com/download/VC11/
Pour utiliser cette version vous devez installer la version 64 bits de Visual C++ pour Visual Studio 2012 update 3

Publicités

Apache 2.4 sous Windows – Nouvelle version disponible

Depuis le 25 Février 2013 la version 2.4.4 d’Apache est disponible.

Les versions 32 bits et 64 bits sont disponibles sur le site Apache lounge :
version 32 bits : http://www.apachelounge.com/download/
version 64 bits : http://www.apachelounge.com/download/win64/

Apache 2.4 sous Windows – Configuration de PHP

Dans cet article je vais vous parler des configurations de PHP en module et en FastCGI sous Apache 2.4 sous Windows 7. Cette configuration fonctionne également sous Windows 2008 R2.

La configuration en module utilise moins de ressources mémoire, de ressources CPU et est plus rapide que la configuration FastCGI.
Le gros inconvénient du module est que vous ne pouvez pas avoir plusieurs versions de PHP en même temps sur votre serveur Apache alors que FastCGI offre cette possibilité.

Je ne reviens pas sur l’installation d’Apache, je pars du principe qu’Apache est installé et fonctionnel ( http://localhost affiche It works !).
J’utilise PHP 5.4.8. Je ne parlerai pas de la configuration de PHP (fichier php.ini).
Si le runtime Microsoft 2008 c++ n’est pas installé n’oubliez pas de le faire sinon PHP 5.4 ne fonctionnera pas.

Ma configuration des dossiers est la suivante :

Le dossier d’Apache e:\serveur_web\apache24
Le dossier du site web e:\serveur_web\apache24\htdocs
Le dossier de PHP e:\serveur_web\php

PHP fournit des versions thread safe et non thread safe pour chacune de ses branches (5.2, 5.3 et 5.4).
Pour une configuration en module il faut prendre une version thread safe de PHP.
Pour une configuration FastCGI il faut prendre une version non thread safe de PHP.

PHP en module d’Apache

Pour installer PHP en tant que module d’Apache il faut télécharger à partir du site http://windows.php.net/download le fichier zip VC9 x86 Thread Safe.
Extraire le contenu de ce fichier dans le dossier e:\serveur_web\php.
Dans ce dossier vous remarquerez qu’il existe les fichiers php5apache2_2.dll et php5apache2_3.dll qui permettent dans les versions Apache 2.2 et Apache 2.3 d’utiliser PHP en tant que module.
Il n’existe pas de fichier php5apache2_4.dll pour Apache 2.4.
Pour obtenir php5apache2_4.dll allez sur le site http://www.apachelounge.com/download/ puis télécharger php5apache2_4.dll-php-5.4-win32.zip.
Ouvrir ce fichier, aller dans le répertoire PHP 5.4.8 puis extraire le fichier php5apache2_4.dll dans le dossier e:\serveur_web\php.
Ouvrir le fichier e:\serveur_web\apache24\conf\httpd.conf puis ajouter les lignes suivantes

PHPIniDir "e:/serveur_web/php"
LoadModule php5_module "e:/serveur_web/php/php5apache2_4.dll"
<FilesMatch \.php$>
SetHandler application/x-httpd-php
</FilesMatch>

Enregistrer le fichier.
Ouvrir une fenêtre de commandes puis exécuter e:\serveur_web\apache24\bin\httpd –t pour vérifier la syntaxe du fichier httpd.conf. Si tout est OK redémarrer le service Apache2.4.
Créer un fichier info.php dans e:\serveur_web\apache24\htdocs contenant < ?php phpinfo() ; ?>
Lancez votre navigateur puis tapez http://localhost/info.php dans la barre d’adresse.
Une page avec toute la configuration PHP doit s’afficher.
En regardant la ligne Server API vous verrez la valeur Apache 2.4 Handler Apache Lounge qui signifie que vous êtes configuré en module.
Regardez également la ligne Loaded Configuration File pour vérifier que le fichier php.ini est bien chargé.

Votre configuration de PHP en module est réussie.

PHP en FastCGI

Pour la configuration en FastCGI il faut récupérer le fichier mod_fcgid-2.3.7-win32.zip sur le site http://www.apachelounge.com/download/
Ouvrez ce zip, aller dans le dossier mod_fcgid puis extraire le fichier mod_fcgid.so dans e:\serveur_web\Apache24\modules.
Ouvrez le fichier e:\serveur_web\apache24\conf\httpd.conf.
Dans la partie du fichier où se trouvent tous les LoadModule ajoutez à la fin la ligne

LoadModule fcgid_module modules/mod_fcgid.so

Aller à la fin du fichier et ajouter les lignes suivantes

FcgidInitialEnv PHPRC "E:\serveur_web\php\"
<FilesMatch \.php$>
AddHandler fcgid-script .php
FcgidWrapper "E:\serveur_web\php\php-cgi.exe" .php
</FilesMatch>

Ces lignes sont le minimum pour faire fonctionner FastCGI pour connaitre toutes les directives de ce module allez sur http://httpd.apache.org/mod_fcgid/mod/mod_fcgid.html
Pour terminer allez dans la section <directory "e:\serveur_web\apache24\htdocs"></directory> vous devez avoir une directive Options, ajouter ExecCGI

Options Indexes FollowSymLinks ExecCGI

Enregistrer le fichier.
Ouvrir une fenêtre de commandes puis exécuter e:\serveur_web\apache24\bin\httpd –t pour vérifier la syntaxe du fichier httpd.conf. Si tout est OK redémarrer le service Apache2.4
Créer un fichier info.php dans e:\serveur_web\apache24\htdocs contenant < ?php phpinfo() ; ?>
Lancez votre navigateur puis tapez http://localhost/info.php dans la barre d’adresse.
Une page avec toute la configuration PHP doit s’afficher.
Cette fois ci en regardant la ligne Server API vous verrez la valeur CGI/FastCGI.

Vous avez réussi votre configuration de PHP en FastCGI.

Pour toutes remarques ou questions n’hésitez pas à laisser un commentaire 🙂

Apache 2.4 sous Windows – Héberger plusieurs sites web avec les serveurs virtuels

Pour ceux qui souhaitent faire du développement web ou héberger des sites web, il est bien utile de pouvoir héberger sur une seule machine plusieurs sites web.

Dans cet article, je vais vous expliquer comment réaliser une telle configuration sous Apache 2.4 sous Windows 7 en utilisant les virtual hosts, en français serveurs virtuels. Il existe 2 configurations possibles, une par nom et une par IP, ici je ferai une configuration par nom. Cette configuration fonctionne également sous Windows 2008 R2.

Apache gère nativement les hôtes virtuels, il n’y a rien de particulier à activer.

Si vous regardez le contenu du fichier httpd.conf et que vous recherchez la chaine # Virtual hosts vous constatez qu’il y a la directive Include conf/extra/httpd-vhosts.conf indiquant que les serveurs virtuels sont définis dans le fichier httpd-vhosts.conf, vous pouvez également les définir directement dans le fichier httpd.conf.

Plantons un peu le décor.

Je vais mettre en place 5 sites web, 4 seront réellement mis en place, le dernier sera juste déclaré dans le DNS histoire de voir le comportement d’apache.

La configuration des serveurs virtuels se décompose en 3 étapes :
1. Créer les dossiers d’hébergement des différents sites
2. Déclarer les sites dans le DNS.
3. Configurer les serveurs virtuels.

1. Création des dossiers d’hébergement

Je crée les différents dossiers où seront placés les fichiers et les logs de chaque site comme décrit ci-dessous

Nom DNS Emplacement des fichiers
Site 1  www.site1.fr Fichiers : E:\serveur_web\www\site1
Logs : E:\serveur_web\apache24\logs\site1
Site 2  www.site2.fr Fichiers : E:\serveur_web\www\site2
Logs : E:\serveur_web\apache24\logs\site2
Site 3  www.site3.fr Fichiers : E:\serveur_web\www\site3
Logs : E:\serveur_web\apache24\logs\site3
Site 4  www.site4.fr Fichiers : E:\serveur_web\www\site4
Logs : E:\serveur_web\apache24\logs\site4
Site5 Aucun Aucun

Dans le dossier racine de chaque site je crée un fichier index.html.

Dossier racine Contenu
E:\serveur_web\www\site1 <HTML>
<HEAD>
<TITLE>Site 1</TITLE>
</HEAD>
<BODY>
SITE 1
</BODY>
</HTML>
E:\serveur_web\www\site2 <HTML>
<HEAD>
<TITLE>Site 2</TITLE>
</HEAD>
<BODY>
SITE 2
</BODY>
</HTML>
E:\serveur_web\www\site3 <HTML>
<HEAD>
<TITLE>Site 3</TITLE>
</HEAD>
<BODY>
SITE 3
</BODY>
</HTML>
E:\serveur_web\www\site4 <HTML>
<HEAD>
<TITLE>Site 4</TITLE>
</HEAD>
<BODY>
SITE 4
</BODY>
</HTML>

2. Déclaration des sites dans le DNS

Lancez notepad en l’exécutant en tant qu’administrateur (clic droit sur notepad > exécuter en tant qu’administrateur)
Faire Fichier > Ouvrir… puis sélectionnez le fichier C:\Windows\System32\drivers\etc\hosts Ajouter les lignes suivantes

127.0.0.1 www.site1.fr
127.0.0.1 www.site2.fr
127.0.0.1 www.site3.fr
127.0.0.1 www.site4.fr
127.0.0.1 www.site5.fr

Enregistrer le fichier.

3. Configuration des serveurs virtuels

Il faut créer une section <virtualhost @IP :port></virtualhost> avec au minimum une directive ServerName et DocumentRoot pour chaque serveur virtuel.
Toutes les directives qui ont un contexte virtual host peuvent être utilisées pour affiner la configuration de chaque serveur virtuel.
Dans la configuration par nom que je réalise @IP aura la valeur * qui signifie n’importe quelle adresse ip.

Voyons d’un peu plus près le fonctionnement.
Lorsqu’une requête arrive sur le serveur apache, celui-ci recherche la section <virtualhost> qui correspond le mieux au couple @IP :port. Si plusieurs <virtualhost> correspondent, le serveur sélectionne celui correspondant au nom d’hote de la requête, il regarde la directive ServerName dans chaque section <virtualhost>. Si aucun nom d’hote ne correspond, c’est le premier serveur virtuel qui est utilisé, qui est donc le serveur virtuel par défaut.

Je choisis de déclarer les hôtes dans le fichier conf/extra/httpd-vhosts.conf donc il faut décommenter la ligne Include conf/extra/httpd-vhosts.conf en enlevant le # dans le fichier httpd.conf.

Dans le fichier httpd-vhosts.conf, il y a par défaut des exemples de déclaration d’hôte virtuel, ça vous donne une idée de la syntaxe d’une section <virtualhost></virtualhost>.
Je supprime les exemples et je déclare les sections <virtualhost></virtualhost> pour chaque site

<VirtualHost *:80>
ServerName www.site1.fr
DocumentRoot "E:/serveur_web/www/site1"
<Directory "E:/serveur_web/www/site1">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
CustomLog "logs/site1/site1-access.log" common
ErrorLog "logs/site1/site1-error.log"
</VirtualHost>
<VirtualHost *:80>
ServerName www.site2.fr
DocumentRoot "E:/serveur_web/www/site2"
<Directory "E:/serveur_web/www/site2">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
CustomLog "logs/site2/site2-access.log" common
ErrorLog "logs/site2/site2-error.log"
</VirtualHost>
<VirtualHost *:80>
ServerName www.site3.fr
DocumentRoot "E:/serveur_web/www/site3"
<Directory "E:/serveur_web/www/site3">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
CustomLog "logs/site3/site3-access.log" common
ErrorLog "logs/site3/site3-error.log"
</VirtualHost>
<VirtualHost *:80>
ServerName www.site4.fr
DocumentRoot "E:/serveur_web/www/site4"
<Directory "E:/serveur_web/www/site4">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
CustomLog "logs/site4/site4-access.log" common
ErrorLog "logs/site4/site4-error.log"
</VirtualHost>

Enregistrer le fichier.

Pour vérifier qu’il n’y a pas d’erreur de syntaxe dans la déclaration de vos serveurs virtuels tapez la commande Apache2.4\bin\httpd –S dans une invite de commande.
Si la commande ne retourne rien c’est que tout va bien, vous pouvez relancez le service Apache2.4.

Il ne reste plus qu’à tester.

Lancez votre navigateur puis saisissez l’adresse http://www.site1.fr SITE1 doit s’afficher dans votre navigateur.
Saisissez http://www.site2.fr SITE 2 doit s’afficher et ainsi de suite jusqu’au site 4.
Maintenant saisissez http://www.site5.fr, vous pouvez constater que SITE 1 s’affiche dans le navigateur. C’est le comportement normal d’apache, le serveur virtuel pour http://www.site5.fr n’est pas déclaré donc le premier serveur virtuel de la liste sera utilisé.

Pour toutes vos questions n’hésitez pas à me laisser un commentaire 🙂