Logo Khaganat
Traductions de cette page?:

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 mariadb-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 Mysql au lieu de Mariadb, mais c'est moins bien…

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).

Proxy

Certains services sont accessibles via des ports particuliers. C'est ce que fait Etherpad par exemple : lors de son installation, il est accessible à l'adresse http://monserveur.com:9001.

Pour qu'on puisse y accéder via l'adresse web http://monserveur.com/pad, il faut mettre un proxy en place dans Apache.

Commencer par activer les modules de proxy :

a2enmod proxy proxy_http

Puis ajouter ce genre d'information dans /etc/apache2/sites-availables/000-default.conf :

<VirtualHost *:80>

  ProxyVia On
  ProxyRequests Off
  ProxyPass /pad/ http://localhost:9001/
  ProxyPassReverse /pad/ http://localhost:9001/
  ProxyPreserveHost on
  <Proxy *>
    Options FollowSymLinks MultiViews
    AllowOverride All
    Order allow,deny
    allow from all
  </Proxy>

</VirtualHost>

Relancez le service apache

service apache2 restart

Votre etherpad devrait être accessible à la bonne adresse !

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; 
1)
oui, notre utilisateur test s'appelle “Lambda”.
CC Attribution-Share Alike 4.0 International Driven by DokuWiki
fr/lamp.1473835963.txt.gz · Dernière modification : (modification externe)

Licences Mentions légales Accueil du site Contact Inclusion