Projet

Général

Profil

Competences techniques apache et drupal » Historique » Version 30

Florent Torregrosa, 28/07/2013 10:44
toc à droite

1 1 Florent Torregrosa
h1. Compétences techniques apache et drupal
2 30 Florent Torregrosa
3 30 Florent Torregrosa
{{>toc}}
4 1 Florent Torregrosa
5 7 Julien Enselme
h2. Différences majeures entre les distributions
6 1 Florent Torregrosa
7 8 Julien Enselme
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.
8 8 Julien Enselme
9 8 Julien Enselme
h3. Le nom du service apache
10 8 Julien Enselme
11 8 Julien Enselme
* Pour les distribution basées sur Debian (Ubuntu, Linux Mint,…) : le service s’appelle apache2
12 8 Julien Enselme
* Pour les distributions typées RedHat (Fedora, CentOS,…) : le service s’appelle httpd
13 8 Julien Enselme
14 8 Julien Enselme
h3. Interaction avec les services
15 8 Julien Enselme
16 8 Julien Enselme
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.
17 8 Julien Enselme
18 8 Julien Enselme
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.
19 8 Julien Enselme
20 8 Julien Enselme
h3. Activation des modules Apache
21 8 Julien Enselme
22 8 Julien Enselme
L’activation explicite des modules dépend de votre distributions.
23 8 Julien Enselme
24 8 Julien Enselme
h3. Emplacements des fichiers de configuration
25 8 Julien Enselme
26 8 Julien Enselme
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.
27 1 Florent Torregrosa
28 7 Julien Enselme
h2. Installer et configurer Apache, phpmyadmin
29 7 Julien Enselme
30 9 Julien Enselme
* savoir installer un serveur apache et phpmyadmin (dépend de votre système)
31 9 Julien Enselme
* augmenter sa mémoire dédiée
32 9 Julien Enselme
* avoir drush d'installer (peut-être présent dans les dépôts de votre distributions) et savoir où il est installé : which drush
33 9 Julien Enselme
* 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
34 7 Julien Enselme
35 9 Julien Enselme
 * <code class="php">memory_limit = 512M;</code>
36 9 Julien Enselme
 * <code class="php">post_max_size = 32M;</code>
37 9 Julien Enselme
 * <code class="php">upload_max_filesize = 32M;</code>
38 12 Julien Enselme
 * redémarrer apache
39 12 Julien Enselme
* 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>
40 7 Julien Enselme
41 1 Florent Torregrosa
h2. Savoir ajouter/activer des modules pour le serveur apache (notamment le module pour les url-simplifiées)
42 1 Florent Torregrosa
43 1 Florent Torregrosa
* sudo a2enmod mod_rewrite
44 7 Julien Enselme
* sudo a2ensite NOM_DU_SITE
45 1 Florent Torregrosa
46 7 Julien Enselme
h2. Savoir installer drush et les bibliothèques php
47 1 Florent Torregrosa
48 20 Julien Enselme
* 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.
49 20 Julien Enselme
* Savoir où est installé drush : @drush config@
50 20 Julien Enselme
* Dépendances supplémentaires utiles : @sudo apt-get install curl libcurl3 libcurl3-dev php5-curl@
51 20 Julien Enselme
52 20 Julien Enselme
Pour plus d’information sur Drush, consulter la [[Drush|page dédiée]].
53 1 Florent Torregrosa
54 3 Florent Torregrosa
h2. Pouvoir utiliser un nom de domaine en local
55 1 Florent Torregrosa
56 21 Julien Enselme
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
57 7 Julien Enselme
<pre>127.0.0.1  assos.centrale-marseille.fr</pre>
58 11 Julien Enselme
59 21 Julien Enselme
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.
60 7 Julien Enselme
61 22 Julien Enselme
h2. Pouvoir créer des vhost
62 1 Florent Torregrosa
63 27 Julien Enselme
La méthode est donnée en annexe [[Competences_techniques_apache_et_drupal#Annexe-Vhosts|ici]]
64 7 Julien Enselme
65 1 Florent Torregrosa
h2. Pouvoir reproduire en local un site en particulier
66 1 Florent Torregrosa
67 23 Julien Enselme
Pouvoir télécharger en local juste le minimum de fichiers. Le minimum c’est :
68 1 Florent Torregrosa
69 23 Julien Enselme
* tout le htmltest sauf le dossier sites
70 23 Julien Enselme
* dans sites/ il faut ne prendre que le dossier default et le dossier du site qui nous concerne.
71 23 Julien Enselme
* 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.
72 1 Florent Torregrosa
73 23 Julien Enselme
 * sur sa machine : se faire un dossier d6 et un dossier d7
74 23 Julien Enselme
 * _Exemple pour le site des annales, à apapter_ :
75 14 Julien Enselme
<pre>
76 14 Julien Enselme
 <code>cd d6</code>
77 14 Julien Enselme
  <code>rsync -lr --exclude sites assos@sas1.centrale-marseille.fr:html/* .</code>
78 14 Julien Enselme
  <code>mkdir sites</code>
79 14 Julien Enselme
  <code>cd sites</code>
80 14 Julien Enselme
  <code>rsync -lr assos@sas1.centrale-marseille.fr:html/sites/default .</code>
81 14 Julien Enselme
  <code>rsync -lr assos@sas1.centrale-marseille.fr:html/sites/assos.centrale-marseille.fr.annales .</code> (étape longue)
82 14 Julien Enselme
</pre>
83 7 Julien Enselme
84 1 Florent Torregrosa
h2. Pouvoir télécharger la base de donnée d’un seul site en particulier
85 2 Florent Torregrosa
86 15 Julien Enselme
h3. Avec phpmyadmin
87 1 Florent Torregrosa
88 15 Julien Enselme
Dans phpmyadmin :
89 15 Julien Enselme
 * exporter
90 15 Julien Enselme
 * options personnalisées
91 15 Julien Enselme
 * choisir que les tables qui vous intéressent
92 15 Julien Enselme
 * laisser les autres options
93 15 Julien Enselme
 * enregistrer
94 15 Julien Enselme
 * ça enregistre dans votre dossier de téléchargements sur votre machine
95 1 Florent Torregrosa
96 15 Julien Enselme
h3. Avec drush
97 1 Florent Torregrosa
98 15 Julien Enselme
Indispensable car parfois le fichier téléchargé par phpmyadmin est trop gros et dépasse la limite autorisée.
99 15 Julien Enselme
100 15 Julien Enselme
# sur le sas, pour le site des annales par exemple :
101 15 Julien Enselme
<pre>
102 15 Julien Enselme
<code>dump_site annales</code>
103 15 Julien Enselme
<code>cd Desktop/dump_individuels</code>
104 15 Julien Enselme
</pre>
105 15 Julien Enselme
*ou si le site est dans une base de données séparée :*
106 15 Julien Enselme
<pre>
107 15 Julien Enselme
<code>cd DOSSIER DU SITE</code>
108 15 Julien Enselme
<code>drush sql-dump > fichier.sql</code>
109 15 Julien Enselme
</pre>
110 15 Julien Enselme
# sur sa machine :
111 15 Julien Enselme
<pre>scp assos@sas1.centrale-marseille.fr:Desktop/dump_individuels/annalesDATE .</pre>
112 1 Florent Torregrosa
113 24 Julien Enselme
Il existe peut-être une commande drush qui fait tout. À creuser.
114 24 Julien Enselme
115 1 Florent Torregrosa
h2. Monter un site en local
116 1 Florent Torregrosa
117 25 Julien Enselme
# Monter un seul vhost pour assos.centrale-marseille.fr (il sera valable pour tous les sous sites, il ne sera jamais édité)
118 25 Julien Enselme
# Télécharger les fichiers et la base de donnée du site en question
119 25 Julien Enselme
# Injecter la dbb en local (utiliser le phpmyadmin en local ou mysql -u root -pmotdepasse nomdelabase < fichier.sql)
120 25 Julien Enselme
# Modifier le settings.php du site en question pour donner les informations de connection mysql et modifier $base_url
121 25 Julien Enselme
# Pour aller plus vite, renommer le dossier du site en default
122 25 Julien Enselme
# Désactiver le mode maintenance @drush vset maintenance_mode 0@ et les urls simplifiées si besoin @drush vset clean_url 0@
123 25 Julien Enselme
# Activer éventuellement les rapports d’erreurs @drush vset error_level NB@
124 25 Julien Enselme
# Vider les caches
125 1 Florent Torregrosa
126 13 Julien Enselme
h2. Installer le script drush de mise à jour
127 1 Florent Torregrosa
128 13 Julien Enselme
* suivre la procédure d’installation donnée "ici":http://drupal.org/project/drush_sup
129 1 Florent Torregrosa
* critère de validation : la commande suivante marche : drush sup
130 1 Florent Torregrosa
131 1 Florent Torregrosa
h2. Exécuter correctement le script de mise à jour
132 1 Florent Torregrosa
133 1 Florent Torregrosa
* lire la doc de drush sup
134 1 Florent Torregrosa
* exécuter drush sup avec les bons arguments
135 7 Julien Enselme
136 7 Julien Enselme
h2. Alias drush
137 7 Julien Enselme
138 7 Julien Enselme
139 7 Julien Enselme
TODO (dans la doc drush ?)
140 7 Julien Enselme
installer dom, xml (paquet php)
141 1 Florent Torregrosa
142 3 Florent Torregrosa
h1. Annexe : Nom de domaine
143 1 Florent Torregrosa
144 26 Julien Enselme
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@.
145 26 Julien Enselme
146 26 Julien Enselme
{{tip(Ne pas oublier de relancer apache.)}}
147 1 Florent Torregrosa
148 3 Florent Torregrosa
h1. Annexe : Vhosts
149 1 Florent Torregrosa
150 28 Julien Enselme
Exemple : créer le domaine titi.local
151 28 Julien Enselme
152 1 Florent Torregrosa
h2. Pour les distributions basées sous Debian
153 1 Florent Torregrosa
154 28 Julien Enselme
* Dans /etc/apache2/sites-available/ créer un fichier titi. Le contenu de titi est :
155 28 Julien Enselme
156 1 Florent Torregrosa
<pre>
157 1 Florent Torregrosa
<VirtualHost *:80>
158 28 Julien Enselme
       ServerAdmin webmaster@localhost
159 28 Julien Enselme
       ServerName titi.local
160 28 Julien Enselme
       ServerAlias titi.local
161 1 Florent Torregrosa
162 28 Julien Enselme
       DocumentRoot /chemin/dossier_site
163 1 Florent Torregrosa
164 28 Julien Enselme
       <Directory /chemin/dossier_site/>
165 28 Julien Enselme
               Options Indexes FollowSymLinks MultiViews
166 28 Julien Enselme
               AllowOverride All
167 28 Julien Enselme
               Order allow,deny
168 28 Julien Enselme
               allow from all
169 28 Julien Enselme
       </Directory>
170 1 Florent Torregrosa
171 28 Julien Enselme
       ErrorLog ${APACHE_LOG_DIR}/titi.error.log
172 1 Florent Torregrosa
173 28 Julien Enselme
       # Possible values include: debug, info, notice, warn, error, crit,
174 28 Julien Enselme
       # alert, emerg.
175 28 Julien Enselme
       LogLevel warn
176 1 Florent Torregrosa
177 28 Julien Enselme
       CustomLog ${APACHE_LOG_DIR}/titi.access.log combined
178 1 Florent Torregrosa
</VirtualHost>
179 1 Florent Torregrosa
</pre>
180 28 Julien Enselme
181 28 Julien Enselme
* Créer le fichier test.html dans /chemin/dossier_site  et mettre dedans <pre><h1>TITI</h1></pre>
182 28 Julien Enselme
* Activer le site : @sudo a2ensite titi@
183 28 Julien Enselme
* *ou*
184 28 Julien Enselme
* 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)
185 28 Julien Enselme
186 28 Julien Enselme
 * <code>cd /etc/apache2/sites-enabled/</code>
187 28 Julien Enselme
 * <code>ln -s ../sites-available/titi .</code>
188 28 Julien Enselme
189 28 Julien Enselme
* Ajouter l’entrée titi.local dans le fichier /etc/hosts
190 1 Florent Torregrosa
<pre>
191 28 Julien Enselme
127.0.0.1        titi.local
192 1 Florent Torregrosa
</pre>
193 1 Florent Torregrosa
194 28 Julien Enselme
* Redémarrer apache : <code>sudo service apache2 restart</code>
195 28 Julien Enselme
* Consulter  titi.local/test.html
196 28 Julien Enselme
197 28 Julien Enselme
h2. Pour Fedora et les distributions basées sur RHEL (CentOS, Scientific Linux…)
198 28 Julien Enselme
199 28 Julien Enselme
* Dans /etc/httpd/cond.d/ créer un fichier titi.conf. Le contenu de titi est :
200 28 Julien Enselme
201 1 Florent Torregrosa
<pre>
202 28 Julien Enselme
<VirtualHost *:80>
203 28 Julien Enselme
       ServerAdmin webmaster@localhost
204 28 Julien Enselme
       ServerName titi.local
205 28 Julien Enselme
       ServerAlias titi.local
206 28 Julien Enselme
207 28 Julien Enselme
       DocumentRoot /chemin/dossier_site
208 28 Julien Enselme
209 28 Julien Enselme
       <Directory /chemin/dossier_site/>
210 28 Julien Enselme
               Options Indexes FollowSymLinks MultiViews
211 28 Julien Enselme
               AllowOverride All
212 28 Julien Enselme
               Order allow,deny
213 28 Julien Enselme
               allow from all
214 28 Julien Enselme
       </Directory>
215 28 Julien Enselme
216 28 Julien Enselme
       # Possible values include: debug, info, notice, warn, error, crit,
217 28 Julien Enselme
       # alert, emerg.
218 28 Julien Enselme
       LogLevel warn
219 28 Julien Enselme
220 28 Julien Enselme
</VirtualHost>
221 4 Florent Torregrosa
</pre>
222 28 Julien Enselme
223 28 Julien Enselme
* Créer le fichier test.html dans /chemin/dossier_site  et mettre dedans <pre><h1>TITI</h1></pre>
224 28 Julien Enselme
* Ajouter l’entrée titi.local dans le fichier /etc/hosts
225 1 Florent Torregrosa
<pre>
226 28 Julien Enselme
127.0.0.1        titi.local
227 1 Florent Torregrosa
</pre>
228 4 Florent Torregrosa
229 28 Julien Enselme
* Redémarrer apache :
230 28 Julien Enselme
231 28 Julien Enselme
 * Fedora >= 15 (basées sur systemd) : @systemctl restart httpd@
232 28 Julien Enselme
 * Fedora < 15, CentOS… <code>service httpd restart</code>
233 28 Julien Enselme
* Consulter  titi.local/test.html
234 28 Julien Enselme
235 4 Florent Torregrosa
h2. Pour Mageia 3
236 4 Florent Torregrosa
237 1 Florent Torregrosa
* Dans /etc/httpd/conf/sites.d/ créer un fichier nom_du_fichier.conf dont le contenu est :
238 1 Florent Torregrosa
<pre>
239 29 Florent Torregrosa
<VirtualHost *:80>
240 29 Florent Torregrosa
  ServerAdmin webmaster@localhost
241 4 Florent Torregrosa
242 29 Florent Torregrosa
  ServerAlias alias_du_site_dans_le_ficher_hosts
243 4 Florent Torregrosa
244 29 Florent Torregrosa
  DocumentRoot /chemin/dossier_site
245 29 Florent Torregrosa
  <Directory /chemin/dossier_site>
246 29 Florent Torregrosa
    Options FollowSymLinks Includes ExecCGI MultiViews
247 29 Florent Torregrosa
    AllowOverride All
248 29 Florent Torregrosa
    Order allow,deny
249 29 Florent Torregrosa
    allow from all
250 29 Florent Torregrosa
    Satisfy any
251 29 Florent Torregrosa
    deny from none
252 29 Florent Torregrosa
  </Directory>
253 4 Florent Torregrosa
254 29 Florent Torregrosa
  ErrorLog /var/log/httpd/nom_du_site-error.log
255 29 Florent Torregrosa
  CustomLog /var/log/httpd/nom_du_site-access.log combined
256 4 Florent Torregrosa
257 29 Florent Torregrosa
  # Possible values include: debug, info, notice, warn, error, crit,
258 29 Florent Torregrosa
  # alert, emerg.
259 29 Florent Torregrosa
  LogLevel warn
260 29 Florent Torregrosa
</VirtualHost>
261 2 Florent Torregrosa
</pre>
262 1 Florent Torregrosa
263 1 Florent Torregrosa
* créer un dossier (avec un Drupal dedans) appelé dossier_site dans /chemin/
264 1 Florent Torregrosa
* restart apache
265 1 Florent Torregrosa
<pre>
266 29 Florent Torregrosa
sudo systemctl restart httpd.service
267 1 Florent Torregrosa
</pre>
268 1 Florent Torregrosa
269 29 Florent Torregrosa
* consulter  alias_du_site_dans_le_ficher_hosts