Projet

Général

Profil

Competences techniques apache et drupal » Historique » Révision 36

Révision 35 (Julien Enselme, 07/02/2014 17:10) → Révision 36/40 (Florent Torregrosa, 16/08/2014 16:52)

Afin de monter des sites correctement en local il est bon de maîtriser les points détaillés ci-après. 

 {{>toc}} 

 h1. Différences majeures entre les distributions 

 Bien que parfois très semblables, les distributions GNU/Linux diffèrent dans leur fonctionnement. Afin de bien comprendre la suite de ce document et d’éviter quelques incompréhensions, nous proposons une liste des différences majeures et des points principaux à adapter. La liste de distribution donnée dans chaque type n’est aucunement exhaustive, tout comme la liste des points de différences. 

 h2. Le nom du service apache 

 * Pour les distribution basées sur Debian (Ubuntu, Linux Mint,…) : le service s’appelle apache2 
 * Pour les distributions typées RedHat (Fedora, CentOS,…) : le service s’appelle httpd 

 h2. Interaction avec les services 

 Historiquement les distributions utilisaient le service init pour démarrer et la commande <code>service</code> pour interragir avec les services de la façon suivante : <code>service apache2 restart</code>. Cela est toujours le cas sur Debian. 

 De plus en plus de distributions (Fedora, Mageia, OpenSUSE,…) utilisent de nos jours systemd qui gèrent aussi les services via la commande <code>systemctl</code> de la façon suivante : <code>systemctl restart httpd</code>. La commande <code>service</code> est dans la plupart des cas toujours opérationnelle pour des raisons de compatibilités. 

 h2. Activation des modules Apache 

 L’activation explicite des modules dépend de votre distributions. 

 h2. Emplacements des fichiers de configuration 

 Suivant votre distribution l’emplacement des fichiers de configuration peut varier. Il y a une constante toute fois : ils sont souvent dans /etc/NOM_DU_SERVICE. 

 h1. Installer et configurer Apache, phpmyadmin 

 * savoir installer un serveur apache et phpmyadmin (dépend de votre système) 
 * augmenter sa mémoire dédiée 
 * avoir drush d'installer (peut-être présent dans les dépôts de votre distributions) et savoir où il est installé : which drush 
 * augmenter la taille maximale des fichiers pouvant être importés dans phpmyadmin (dans le(s) php.ini, la méthode suivante est basée sur les systèmes basés sur debian. À adapter pour votre système.). Il faut trouver et modifier les lignes suivantes dans /etc/php5/apache2/php.ini et /etc/php5/cli/php.ini 

  * <code class="php">memory_limit = 512M;</code> 
  * <code class="php">post_max_size = 32M;</code> 
  * <code class="php">upload_max_filesize = 32M;</code> 
  * redémarrer apache 
 * savoir recharger la configuration d’apache et le redémarrer : <code class="bash">service apache2 reload</code> et <code class="bash">service apache2 restart</code> 

 

 h1. Savoir activer des modules apache 

 * sudo a2enmod mod_rewrite ou sudo a2enmod rewrite 
 * sudo a2ensite NOM_DU_SITE 

 

 h1. Savoir installer drush et les bibliothèques php 

 * Si drush est fourni dans les dépôts de votre distribution, l’installer depuis ceux-ci. Si votre distribution fourni également drupal, il peut être intéressant de l’installer également pour avoir la liste des dépendances. L’installation de drupal via drush est la méthode recommandée. 
 * Savoir où est installé drush : @drush config@ 
 * Dépendances supplémentaires utiles : @sudo apt-get install curl libcurl3 libcurl3-dev php5-curl@ 

 Pour plus d’information sur Drush, consulter la [[Drush|page dédiée]]. 

 h1. Pouvoir utiliser un nom de domaine en local 

 Quand je vais sur assos.centrale-marseille.fr, c’est mon site local que je veux voir et non pas celui de centrale. Il suffit de modifier le fichier hosts, situé dans /etc en ajoutant la ligne 
 <pre>127.0.0.1    assos.centrale-marseille.fr</pre> 

 Constater qu’en allant sur assos.centrale-marseille.fr on tombe sur la page par defaut de notre apache (la page sur laquelle on tombe dépend de la configuration d’apache). On peut vérifier avec le module Firefox _show ip_ qui donne l’IP du site sur lequel on est. Si l’IP affichée est 127.0.0.1, c’est bon. 

 h1. Pouvoir créer des vhost 

 La méthode est donnée en annexe [[Competences_techniques_apache_et_drupal#Annexe-Vhosts|ici]] 

 h1. Pouvoir reproduire en local un site en particulier 

 Pouvoir télécharger en local juste le minimum de fichiers. Le minimum c’est : 

 * tout le htmltest sauf le dossier sites 
 * dans sites/ il faut ne prendre que le dossier default et le dossier du site qui nous concerne. 
 * pouvoir se démerder (script ou suite de ligne de commande ou …) pour pouvoir faire ça efficacement (une suite de commande scp ou rsync n’est pas une mauvaise idée). Jenselme avait commencé un script qui fonctionne presque pour la réplication des sites en local et possède des capacités de réplication sur le réseau. Idée donnée par dgeo à jenselme : utiliser drush avec entre autre @drush rsync@. À creuser. 

  * sur sa machine : se faire un dossier d6 et un dossier d7 
  * _Exemple pour le site des annales, à apapter_ : 
 <pre> 
  <code>cd d6</code> 
   <code>rsync -lr --exclude sites assos@sas1.centrale-marseille.fr:html/* .</code> 
   <code>mkdir sites</code> 
   <code>cd sites</code> 
   <code>rsync -lr assos@sas1.centrale-marseille.fr:html/sites/default .</code> 
   <code>rsync -lr assos@sas1.centrale-marseille.fr:html/sites/assos.centrale-marseille.fr.annales .</code> (étape longue) 
 </pre> 

 h1. Pouvoir télécharger la base de donnée d’un site en particulier 

 h2. Avec phpmyadmin 

 Dans phpmyadmin : 

  * exporter 
  * options personnalisées 
  * choisir que les tables qui vous intéressent 
  * laisser les autres options 
  * enregistrer 
  * ça enregistre dans votre dossier de téléchargements sur votre machine 

 h2. Avec drush 

 Indispensable car parfois le fichier téléchargé par phpmyadmin est trop gros et dépasse la limite autorisée. 

 # sur le sas, pour le site des annales par exemple : 
 <pre> 
 <code>dump_site annales</code> 
 <code>cd Desktop/dump_individuels</code> 
 </pre> 
 *ou si le site est dans une base de données séparée :* 
 <pre> 
 <code>cd DOSSIER DU SITE</code> 
 <code>drush sql-dump > fichier.sql</code> 
 </pre> 
 # sur sa machine : 
 <pre>scp assos@sas1.centrale-marseille.fr:Desktop/dump_individuels/annalesDATE .</pre> 

 Il existe peut-être une commande drush qui fait tout. À creuser. 

 h1. Monter un site en local 

 # Monter un seul vhost pour assos.centrale-marseille.fr (il sera valable pour tous les sous sites, il ne sera jamais édité) 
 # Télécharger les fichiers et la base de donnée du site en question 
 # Injecter la dbb en local (utiliser le phpmyadmin en local ou mysql -u root -pmotdepasse nomdelabase < fichier.sql) 
 # Modifier le settings.php du site en question pour donner les informations de connection mysql et modifier $base_url 
 # Pour aller plus vite, renommer le dossier du site en default 
 # Désactiver le mode maintenance @drush vset maintenance_mode 0@ et les urls simplifiées si besoin @drush vset clean_url 0@ 
 # Activer éventuellement les rapports d’erreurs @drush vset error_level NB@ 
 # Vider les caches 

 h1. Installer le script drush de mise à jour 

 * suivre la procédure d’installation donnée "ici":http://drupal.org/project/drush_sup 
 * critère de validation : la commande suivante marche : drush sup 

 h1. Exécuter correctement le script de mise à jour 

 * lire la doc de drush sup 
 * exécuter drush sup avec les bons arguments 

 h1. Alias drush 

 Voir la [[Drush#Les-alias-drush|section]] correspondante dans la page traitant de Drush. 

 h1. Annexe : Nom de domaine 

 Il est tout à fait possible de faire pointer n’importe quel nom de domaine sur sa machine locale. Normalement, toutes les unix reposent sur le même principe. Il suffit d’ajouter l’entrée suivante dans /etc/hosts (par exemple pour assos) : @127.0.0.1    assos.centrale-marseille.fr@. 

 {{tip(Ne pas oublier de relancer apache.)}} 

 h1. Annexe : Vhosts 

 Exemple : créer le domaine titi.local 

 h2. Pour les distributions basées sous Debian 

 * Dans /etc/apache2/sites-available/ créer un fichier titi. Le contenu de titi est : 

 <pre> 
 <VirtualHost *:80> 
        ServerAdmin webmaster@localhost 
        ServerName titi.local 
        ServerAlias titi.local 

        DocumentRoot /chemin/dossier_site 

        <Directory /chemin/dossier_site/> 
                Options Indexes FollowSymLinks MultiViews 
                AllowOverride All 
                Order allow,deny 
                allow from all 
        </Directory> 

        ErrorLog ${APACHE_LOG_DIR}/titi.error.log 

        # Possible values include: debug, info, notice, warn, error, crit, 
        # alert, emerg. 
        LogLevel warn 

        CustomLog ${APACHE_LOG_DIR}/titi.access.log combined 
 </VirtualHost> 
 </pre> 

 * Créer le fichier test.html dans /chemin/dossier_site    et mettre dedans <pre><h1>TITI</h1></pre> 
 * Activer le site : @sudo a2ensite titi@ 
 * *ou* 
 * Ajouter un lien symbolique dans /etc/apache2/sites-enabled qui pointe sur le fichiet titi qui est dans /etc/apache2/sites-available/ pour activer le site (méthode manulle) 

  * <code>cd /etc/apache2/sites-enabled/</code> 
  * <code>ln -s ../sites-available/titi .</code> 

 * Ajouter l’entrée titi.local dans le fichier /etc/hosts 
 <pre> 
 127.0.0.1          titi.local 
 </pre> 

 * Redémarrer apache : <code>sudo service apache2 restart</code> 
 * Consulter    titi.local/test.html 

 h2. Pour Fedora et les distributions basées sur RHEL (CentOS, Scientific Linux…) 

 * Dans /etc/httpd/conf.d/ créer un fichier titi.conf. Le contenu de titi est : 

 <pre> 
 <VirtualHost *:80> 
        ServerAdmin webmaster@localhost 
        ServerName titi.local 
        ServerAlias titi.local 

        DocumentRoot /chemin/dossier_site 

        <Directory /chemin/dossier_site/> 
                Options Indexes FollowSymLinks MultiViews 
                AllowOverride All 
                Order allow,deny 
                allow from all 
        </Directory> 

        # Possible values include: debug, info, notice, warn, error, crit, 
        # alert, emerg. 
        LogLevel warn 

 </VirtualHost> 
 </pre> 

 * Créer le fichier test.html dans /chemin/dossier_site    et mettre dedans <pre><h1>TITI</h1></pre> 
 * Ajouter l’entrée titi.local dans le fichier /etc/hosts 
 <pre> 
 127.0.0.1          titi.local 
 </pre> 

 * Redémarrer apache : 

  * Fedora >= 15 (basées sur systemd) : @systemctl restart httpd@ 
  * Fedora < 15, CentOS… <code>service httpd restart</code> 
 * Consulter    titi.local/test.html 

 h2. Pour Mageia 3 

 * Dans /etc/httpd/conf/sites.d/ créer un fichier _nom_du_fichier.conf_ dont le contenu est : 
 <pre> 
 <VirtualHost *:80> 
   ServerAdmin webmaster@localhost 

   ServerAlias alias_du_site_dans_le_ficher_hosts 

   DocumentRoot /chemin/dossier_site 
   <Directory /chemin/dossier_site> 
     Options FollowSymLinks Includes ExecCGI MultiViews 
     AllowOverride All 
     Order allow,deny 
     allow from all 
     Satisfy any 
     deny from none 
   </Directory> 

   ErrorLog /var/log/httpd/nom_du_site-error.log 
   CustomLog /var/log/httpd/nom_du_site-access.log combined 

   # Possible values include: debug, info, notice, warn, error, crit, 
   # alert, emerg. 
   LogLevel warn 
 </VirtualHost> 
 </pre> 

 * créer un dossier (avec un Drupal dedans) appelé dossier_site dans /chemin/ 
 * restart apache 
 <pre> 
 sudo systemctl restart httpd.service 
 </pre> 

 * consulter    alias_du_site_dans_le_ficher_hosts