Utiliser Debian et dérivées

Debian : Installer un serveur LAMP (Apache MariaDB PHP)

Table des matières

lamp_logo



Introduction



LAMP est un acronyme :
  • Linux : Le système d'exploitation
  • Apache : Le serveur Web
  • MySQL / MariaDB : Le serveur de Base de données
  • PHP : Le langage de script

Avec LAMP, on peut donc mettre en place un serveur Web, hébergeant un site web dynamique écrit en PHP, tout en allant chercher des données dans une base MySQL ou maintenant MariaDB, son fork.

Installation



D'abord, on met le système à jour :
Code BASH :
apt update
apt full-upgrade

On va avoir besoin de
  • apache2, c'est le serveur web
  • php c'est le langage php
  • libapache2-mod-php c'est le module apache pour exécuter php
  • mariadb-server c'est le serveur de base de données

Ce tutoriel a été vérifié sur Debian 9, 10 et 11.

Le serveur Web : apache



On installe le serveur apache :
Code BASH :
apt install apache2

A partir de là, si on accède au serveur via son adresse IP, on a la page d'Apache, le serveur web fonctionne.

debian-apache


On peut s'assurer que le service démarrera automatiquement au démarrage :
Code BASH :
systemctl enable apache2

On peut au passage activer quelques modules d'Apache. Sous Debian, c'est la commande a2enmod qui permet cela.
Pour la réécriture d'url :
Code BASH :
a2enmod rewrite

Pour la compression :
Code BASH :
a2enmod deflate

Pour contrôler et modifier les headers :
Code BASH :
a2enmod headers

Tous les modules se trouvent dans /etc/apache2/mods-available et ceux activés dans /etc/apache2/mods-enabled
Après chaque activation de module, il faut relancer apache. moi je préfère juste recharger la configuration :
Code BASH :
systemctl reload apache2

La configuration d'Apache se fait via le fichier /etc/apache2/apache2.conf. C'est la configuration générale :
Code BASH :
vi /etc/apache2/apache2.conf

On peut masquer les infos de version, de distribution en ajoutant dans ce fichier :
Code BASH :
ServerSignature Off

Il faut évidemment recharger la configuration d'apache après chaque modification.

PHP



A noter, si vous voulez une version différente que celle proposée par Debian, consultez : https://www.linuxtricks.fr/wiki/debian-installer-une-version-plus-recente-de-php
D'abord, on installe PHP + le module permettant à apache d'interragir avec PHP :
Code BASH :
apt install php php-cli libapache2-mod-php 

A ce stade, PHP est installé, mais on n'a pas grand chose. Il faut installer des modules en fonction des besoins. Les modules sont nommés de la manière suivante : php-xxx. On peut les lister avec :
Code BASH :
apt search ^php-

Pour notre utilisation, on va installer les plus courants :
Code BASH :
apt install php-{curl,gd,intl,memcache,xml,zip,mbstring,json}

Pour interagir avec SQL :
Code BASH :
apt install php-mysql

Ce paquet permet d'attaquer une base de données MySQL/MariaDB avec mysqli ou pdo.
Une fois tout ça installé, on recharge apache :
Code BASH :
systemctl reload apache2

On va tester le bon fonctionnement de PHP.
On se rend dans le répertoire par défaut de la racine d'apache :
Code BASH :
cd /var/www/html

Et on créé un fichier dans lequel on demande d'afficher les infos PHP :
Code BASH :
echo "<?php phpinfo(); ?>" > test.php

Ensuite, on affiche notre page via le navigateur :

debian-php-avec-apache


On peut éditer les options de PHP via le fichier /etc/php/7.*/apache2/php.ini ou créer un fichier personnalisé dans /etc/php/7.*/apache2/conf.d.

MariaDB : La base de données



Maintenant, il ne reste plus que le moteur de base de données à installer.
On installe donc MariaDB, le serveur :
Code BASH :
apt install mariadb-server

Une fois fait, on démarre l'installation :
Code BASH :
mysql_secure_installation

Une série de questions vont s'afficher.
On définit le mot de passe root :
Code BASH :
Change the root password? [Y/n] Y
New password:
Re-enter new password:
Password updated successfully!

On supprime les utilisateurs anonymes, les connexions distantes de root, etc...
Code BASH :
Remove anonymous users? [Y/n] Y
Disallow root login remotely? [Y/n] Y
Remove test database and access to it? [Y/n] Y
Reload privilege tables now? [Y/n] Y

On teste la connexion à la base de données :
Code BASH :
mysql -u root -p

On créé ensuite un utilisateur avec tous les droits pour ne pas utiliser root :
Code SQL :
CREATE USER 'adrien'@'localhost' IDENTIFIED BY 'mdp';
GRANT ALL PRIVILEGES ON *.* TO 'adrien'@'localhost' WITH GRANT OPTION;
FLUSH PRIVILEGES;

Et on se déconnecte :
Code SQL :
exit

On peut s'assurer que le service se lance à chaque démarrage du serveur :
Code BASH :
systemctl enable mariadb

Notre serveur LAMP est installé :magic:

Les virtualhosts sous Debian...



Pour les virtualhosts, le fichier du virtualhost par défaut est /etc/apache2/sites-available000-default.conf. On peut éditer celui là où, dans la logique debian, si on peut créer plusieurs Virtualhosts pour nos différents sites dans /etc/apache2/sites-available.
Par exemple :
Code BASH :
vi /etc/apache2/sites-available/linuxtricksdebian.conf

Code BASH :
<VirtualHost *:80>
 ServerName linuxtricksdebian.fr
 ServerAlias www.linuxtricksdebian.fr
 
 DocumentRoot /var/www/linuxtricksdebian
 
 <Directory /var/www/linuxtricksdebian>
 Options -Indexes +FollowSymLinks
 AllowOverride All
 Require all granted
 </Directory>
</VirtualHost>

Ensuite, on active le site avec a2ensite :
Code BASH :
a2ensite linuxtricksdebian

Et on recharge apache2 :
Code BASH :
systemctl reload apache2


Activer HTTPS : mod SSL



Si on souhaite activer HTTPS, il faut installer openssl si ce n'est pas déjà fait.
Ensuite, il nous faut activer le module SSL :
Code BASH :
a2enmod ssl

Et activer le site par défaut SSL :
Code BASH :
a2ensite default-ssl

En se connectant en HTTPS, ça fonctionne. On a une erreur de certificat, normal, il est autogénéré. Pour celà, il faut utiliser un certificat reconnu par une autorité de certification ou bien se générer un certificat avec Lets Encrypt : https://www.linuxtricks.fr/wiki/let-s-encrypt-mise-en-place
Cette page a été vue 107964 fois