Contenu | Rechercher | Menus

Serveur web - LAMP

LAMP est un acronyme pour Linux, Apache, MySQL, PHP. C'est une pile logicielle comprenant le système d'exploitation, un serveur HTTP, un système de gestion de bases de données et un langage de programmation interprété, et qui permet de mettre en place un serveur web.

  • Linux : le système d'exploitation, on peut déployer la pile LAMP sur la plupart des distributions GNU/Linux ;
  • Apache : le serveur HTTP, il permet au serveur de communiquer avec le navigateur en utilisant le protocole HTTP(S) ;
  • MySQL : il s'agit d'un serveur de bases de données. Il sert à stocker, à manipuler et à accéder à des listes de données organisées en tableaux. Ce service peut être fournit par le logiciel MySQL ou par MariaDB (fork plus ouvert, plus performant, et 100% compatible MySQL).
  • PHP : PHP est un langage de programmation interprété qui permet de générer du contenu web dynamiquement. Il s'agit la plupart du temps de pages HTML).

Un exemple type : un internaute veut afficher son profil sur un site web. Au moyen de son navigateur il effectue une requête sur un serveur web en appelant une URL sur le domaine du serveur. Le module PHP d'Apache va interpréter un script qui envoie une requête au serveur MySQL en lui demandant les informations de l'utilisateur. Une fois ces informations récupérées, le script PHP met en forme le résultat sous forme de page web (HTML) qui est envoyée au navigateur web.

Installation

On peut déployer la pile LAMP sur n'importe quelle version ou variante d'Ubuntu. La variante Ubuntu server est particulièrement adaptée dans le cas d'un serveur "headless" (sans interface graphique) contrôlable à distance (par ssh notamment).

Méthode recommandée : installation des paquets

À partir d'Ubuntu 16.04 les paquets doivent être installés par le biais d'un terminal pour fonctionner correctement (voir note ci-dessous).

Cette méthode consiste à installer les paquets nécessaires pour Apache, PHP et MySQL :

sudo apt install apache2 php mysql-server libapache2-mod-php php-mysql

ou si vous préférez opter pour MariaDB au lieu de MySQL :

sudo apt install apache2 php mariadb-server libapache2-mod-php php-mysql

La pile LAMP est alors installée. Cependant la plupart des scripts PHP (CMS, forums, applications web en tout genre) utilisent des modules de PHP pour bénéficier de certaines fonctionnalités.
Voici comment installer les modules les plus courants :

sudo apt install php-curl php-gd php-intl php-json php-mbstring php-mcrypt php-xml php-zip

Description des paquets :

  • Le paquet apache2 installe le serveur HTTP Apache 2.
  • Le paquet php méta-paquet permettant d'installer au moins un interpréteur PHP PHP.
  • Le paquet libapache2-mod-php module d'Apache (on peut aussi utiliser PHP en ligne de commande ou indépendamment en FastCGI, ce qui le rend plus performant mais plus compliqué à mettre en place)
  • Le paquet mysql-server installe le serveur de bases données MySQL.
  • Le paquet mariadb-server installe le serveur de base données MariaDB.
  • Le paquet php-mysql installe les module permettant d'utiliser MySQL ou MariaDB avec PHP.
L'installation du paquet mysql-server en cliquant simplement sur un lien apt crée un problème à l'installation ! L'installeur ne demande pas le mot de passe pour mysql-server et l'accès est dès lors compliqué à mysql. Installez bien ce paquet en utilisant le terminal et la commande
sudo apt install mysql-server

comme indiqué juste au dessus. Vous pouvez consulter cette discussion https://forum.ubuntu-fr.org/viewtopic.php?pid=21588812#p21588812 Pour ceux qui auraient le problème de connexion mysql sur la 16.04, voici la manip à faire pour régler le soucis.

sudo mysql -u root
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'le_mot_de_pass_choisi';
mysql> FLUSH PRIVILEGES;
mysql> QUIT;

Une fois les paquets installés, ouvrez un des liens suivants dans votre navigateur :

Si le message « It works! » s'affiche, votre serveur Lamp est correctement installé.

Selon la version installée, vous pouvez aussi avoir une page intitulée « Apache2 Ubuntu Default Page ».

La méthode d'installation décrite ici permet d'obtenir un serveur LAMP pré-configuré et fonctionnel, affichant le contenu du répertoire /var/www/html (par défaut les fichiers index.html ou index.php).

.

Personnalisation de l'installation

Configuration d'Apache 2

La configuration et les détails à propos d'Apache 2 sont accessibles sur la page dédiée à ce serveur HTTP.

Configuration de MySQL

La configuration et les détails à propos du serveur de base de données sont accessibles sur la page dédiée à MySQL ou celle dédiée à MariaDB.

Il est courant d'installer également PHPMyAdmin afin de gérer la base de donnée MySQL dans une interface Web écrite en PHP.
On peut aussi utiliser Adminer qui est plus simple à installer (il s'agit d'un simple fichier PHP).

Configuration du répertoire de travail

La configuration du répertoire de travail est accessible sur cette page

Configuration du démarrage automatique de LAMP

Par défaut, Apache et MySQL ou MariaDB démarrent automatiquement lorsque vous allumez votre ordinateur.

Empêcher LAMP de démarrer automatiquement

Pour empêcher cela :

sudo systemctl disable apache2

Et pour mysql :

sudo systemctl disable mysql

Vous pourrez donc ensuite les lancer manuellement.

Pour Apache :

sudo systemctl start apache2

et pour MySql

sudo systemctl start mysql

Les commandes disponibles sont systemctl start, systemctl stop, et systemctl restart.

Réactiver le démarrage automatique

Pour réactiver les services automatiquement au démarrage, c'est simple :

sudo systemctl enable apache2
sudo systemctl enable mysql

Utilisation et accès au serveur

Une fois l'installation effectuée, le serveur est accessible (via un navigateur internet) à l'une des URL (locales) suivantes:

Il existe des interfaces graphiques pour utiliser Apache et MySQL : localhost-indicator, rapache et webmin (à utiliser avec prudence).

Problèmes courants

Conflits potentiels entre plusieurs versions de PHP

Il est possible que plusieurs versions de PHP soient installées simultanément, par ex. après une mise à jour majeure d'ubuntu si vous avez spécifié le numéro de version de PHP lors de l'installation des paquets, ou si vous avez ajouté un PPA exotique pour installer une version spécifique de PHP (mauvaise idée, il vaut mieux dans ce cas utiliser docker).
Cela peut par ex. rendre des modules de PHP inaccessibles alors qu'ils semblent bien installés.

Vous pouvez vérifier cela avec cette commande :

apt list php* | grep install

Si vous voyez apparaître plusieurs versions de php, par ex. php7.0 php7.1 ou php5.6, vous avez un problème. Dans ce cas supprimez les versions de PHP qui ne correspondent pas à la version proposée par les dépôts officiels d'ubuntu (php7.0 sur Xenial, php7.1 sur Artful) puis réinstallez les paquets absents si nécessaire (libapache2-mod-php, etc).

Conflit entre MySQL et MariaDB

Si vous avez installé MariaDB et que vous cherchez à passer sur MySQL, il est possible que vous rencontriez une erreur de ce type lors de l'installation de votre paquet :

Aborting downgrade from (at least) 10.0 to 5.7.
If are sure you want to downgrade to 5.7, remove the file
/var/lib/mysql/debian-*.flag and try installing again.

ou encore :

mysql_upgrade: Got error: 1524: Plugin 'unix_socket' is not loaded while connecting to the MySQL server
Upgrade process encountered error and will not continue.

Dans ce cas il faut supprimer les paquets ainsi que tous les fichiers de configuration de votre serveur de bases de données. Attention cela rendra les bases de données existantes inaccessibles !

sudo apt autoremove --purge mysql\* mariadb\*
sudo apt clean
sudo mv /var/lib/mysql /var/lib/mysql_bak
sudo mv /etc/mysql /etc/mysql_bak
sudo apt install mysql-server

Voir aussi

Contributeurs : krodelabestiole, oxossi, albanmartel, harren.



Le contenu de ce wiki est sous licence : CC BY-SA v3.0