Ceci est une ancienne révision du document !
LAMP
LAMP est l'acronyme de Linux Apache Mysql Php.
Pour le côté “Linux” de Lamp, tout dépende de votre hébergement et de vos préférences. On conseille aux débutants de prendre une Debian Stable, qui est robuste, sécurisée et pas trop compliquée. Les experts sont aussi nombreux à rester sous cette distribution pour leurs serveurs !
Une bonne part de cette doc se base sur la documentation Ubuntu concernant LAMP.
Installer les paquets de base :
sudo apt-get install apache2 php5 mysql-server libapache2-mod-php5 php5-mysql apache2-utils php5-gd php5-imagick
L'installation de la base mysql va demander la création d'un mot de passe pour “root”. Notez-le bien !
Vous pouvez installer Mariadb au lieu de Mysql, c'est la même chose en mieux…
Se rendre à l'adresse du serveur et admirer la page “It works”. Ça veut dire que c'est installé.
Apache
Apache est en principe fonctionnel de base, mais il y a quelques petites astuces utiles pour une configuration similaire à Khaganat.
Activer la réécriture des URLs
Pour la ferme de wiki ou le pastebin (entre autre), il faut activer la réécriture des URLs.
Lancez la commande :
sudo a2enmod rewrite
Ensuite, éditez /etc/apache2/apache2.conf et ajoutez à la fin (s'il n'y est pas):
<ifModule mod_rewrite.c> RewriteEngine On </ifModule>
Puis vérifier que dans le fichier /etc/apache2/sites-available/default, l'option “AllowOverride” est sur “All” pour les parties visés par la réécriture d'url (tout le dossier /var/www pour pas se compliquer la tâche) :
Options Indexes FollowSymLinks MultiViews AllowOverride all Order allow,deny allow from all
N'oubliez pas de relancer Apache :
/etc/init.d/apache2 restart
Modifier les urls pour aller aux dossiers (Alias)
Avec une configuration basique, Apache indique qu'il faut lire le répertoire /var/www comme répertoire de base du site, chaque dossier se rajoutant à l'adresse. Par exemple si votre dossier www est organisé de la façon suivante :
- www
- dossier1
- page1.html
Alors pour accéder via le web à page1 il faudra mettre dans la barre d'adresse du navigateur www.mon_site.net/dossier1/page1.html
On change ça en faisant des alias dans le fichier /etc/apache2/sites-enable/000-default.conf, de cette façon :
Alias /adresse /var/www/dossier1 <Directory /var/www/dossier1> Options Indexes FollowSymLinks MultiViews AllowOverride All Order allow,deny Allow from all </Directory>
Changez /adresse par ce que vous voulez ; si c'est juste la barre / alors ce sera la racine du site (ce qu'on verra en tapant www.mon_site.net/). Vous pouvez aussi pointer vers des adresses hors de /var/www , par exemple pointer vers home/user/monsite, ce qui vous permet de travailler dans un répertoire avec des droits utilisateurs basique.
Pour un site accessible à tous, les options de cet alias sont bonnes.
Relancer Apache
Pour relancer le serveur apache :
connecté en tant que « root »
/etc/init.d/apache restart
Droits sur www
Plusieurs possibilités pour permettre, en tant qu'utilisateur Lambda1), de modifier ce qui se trouve dans le dossier /var/www.
Le plus simple et rapide est d'attribuer les droits de ce dossier au groupe www-data, et de mettre lambda dans le groupe www-data.
sudo adduser lambda www-data chown -R www-data:www-data /var/www
Méthode alternative :
Pour ajouter l'utilisateur lambda à www-data, il y a aussi la commande
usermod -a -G www-data lambda
Les deux sont similaires.
Relancer la session pour que les droits soient pris en compte pour l'utilisateur en cours.
Il vaut mieux laisser le groupe www-data gérer les droits, de base, parce que sinon c'est un beau bazar. Ajouter l'utilisateur “lambda” dans ce groupe permet de modifier tout sans se prendre la tête.
La sécurité voudrait sans doute que www-data n'aie pas les droits, mais cela demande de bien tout comprendre, sinon apache va juste tout bloquer. Donc, ici, faites simple.
Si certains cms posent problèmes, la suite de commande suivante sur le dossier en question peut réattribuer les droits à www-data et permettre de les résoudre (à lancer en étant root) :
chgrp -R www-data Dossier chown -R www-data Dossier chmod -R g+w Dossier
chgrp pour réaffecter le groupe propriétaire, chown pour changer le propriétaire tout court (moins important, en théorie chgrp devrait déjà régler la plupart des soucis), chmod pour donner les bonnes permissions de lecture/écriture sur le dossier (g pour groupe, + pour ajouter, w pour write, donc “écrire”). L'option -R permet la récursivité (que le changement s'applique dans les sous-dossiers).
Mysql
Phpmyadmin
Installation
Phpmyadmin est considéré comme une potentielle faille de sécurité et s'en passer serait mieux. En même temps, se passer de base de données serait l'idéal…
Bref, en dépit de ces considérations, phpmyadmin est une façon bien pratique de gérer une base de donnée quand on a peu de connaissances, parce que ça assiste bien le travail. Donc… on va tenter de l'installer.
sudo apt-get install phpmyadmin
Sélectionner “apache” dans les options, puis pour la base de donnée, le laisser faire.
Veuillez indiquer le mot de passe pour le compte d'administration qui servira à créer la base de données MySQL ainsi que les utilisateurs. Mot de passe de l'administrateur de la base de données :
C'est le mot de passe root.
Choisissez le mot de passe de la base de donnée… et n'oubliez pas de le faire passer de façon sécurisée aux autres admins.
Localisation web
Par défaut, phpmyadmin est accessible à l’adresse site.net/phpmyadmin, ce qui aide un utilisateur malveillant à trouver la porte. On peut le modifier via le fichier /etc/apache2/conf.d/phpmyadmin.conf, en changeant l'alias par défaut :
Alias /phpmyadmin /usr/share/phpmyadmin
pour, par exemple :
Alias /ploufphpmyadmin /usr/share/phpmyadmin
Le simple ajout du “plouf” devant devrait déjà éviter les attaques automatiques !
Relancer Apache pour que ce soit pris en compte.
Avoir un autre login que “root” serait aussi bien. Mais peut-on le changer facilement ?
Importer une base de donnée
Pour importer une base de donnée via phpmyadmin (par exemple celle du forum, sauvée avant), il faut créer la base, lui associer un utilisateur qui aura les accès sur cette base uniquement, puis importer le .sql sauvegardé.
Si la base est trop grosse, il y aura une erreur. Modifier /etc/php5/apache2/php.ini pour augmenter la taille maximale autorisée. phpmyadmin fait une erreur mettant en lien ce qu'il faut modifier.
Diverses commandes Mysql
Création d'un utilisateur et d'une base mysql pour les différents services :
1) lancer mysql
$ mysql -u root -p
Le mot de passe sera demandé.
2) Créer la base de données :
mysql> create database MaBaseDeDonnées ;
3) Créer un utilisateur et lui donner des droits d'accès à la base sans mot de passe mais uniquement en local :
mysql> GRANT ALL ON MaBaseDeDonnées.* TO Utilisateur@localhost ;
3.1) Faire la même chose mais avec un mot de passe :
mysql> GRANT ALL PRIVILEGES ON MaBaseDeDonnées.* TO Utilisateur@localhost IDENTIFIED BY 'MotDePasse' ;
4) Ne pas oublier de mettre à jour la base :
mysql> FLUSH PRIVILEGES;





