Competences techniques apache et drupal » Historique » Version 14
Julien Enselme, 29/05/2013 14:32
Merge
1 | 1 | Florent Torregrosa | {{toc}} |
---|---|---|---|
2 | |||
3 | 7 | Julien Enselme | h1. Compétences techniques apache et drupal |
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 | |||
9 | h3. Le nom du service apache |
||
10 | |||
11 | * Pour les distribution basées sur Debian (Ubuntu, Linux Mint,…) : le service s’appelle apache2 |
||
12 | * Pour les distributions typées RedHat (Fedora, CentOS,…) : le service s’appelle httpd |
||
13 | |||
14 | h3. Interaction avec les services |
||
15 | |||
16 | 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 | |||
18 | 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 | |||
20 | h3. Activation des modules Apache |
||
21 | |||
22 | L’activation explicite des modules dépend de votre distributions. |
||
23 | |||
24 | h3. Emplacements des fichiers de configuration |
||
25 | |||
26 | 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 | |||
30 | 9 | Julien Enselme | * savoir installer un serveur apache et phpmyadmin (dépend de votre système) |
31 | * augmenter sa mémoire dédiée |
||
32 | * 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 | * 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 | * <code class="php">post_max_size = 32M;</code> |
||
37 | * <code class="php">upload_max_filesize = 32M;</code> |
||
38 | 12 | Julien Enselme | * redémarrer apache |
39 | * 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 | |||
43 | * sudo a2enmod mod_rewrite |
||
44 | 7 | Julien Enselme | * sudo a2ensite NOM_DU_SITE |
45 | 1 | Florent Torregrosa | |
46 | |||
47 | 7 | Julien Enselme | h2. Savoir installer drush et les bibliothèques php |
48 | |||
49 | * 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. |
||
50 | 1 | Florent Torregrosa | * savoir où est installé drush : drush config |
51 | 7 | Julien Enselme | * sudo apt-get install curl libcurl3 libcurl3-dev php5-curl |
52 | 1 | Florent Torregrosa | |
53 | 3 | Florent Torregrosa | h2. Pouvoir utiliser un nom de domaine en local |
54 | 1 | Florent Torregrosa | |
55 | 11 | 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 : ajouter la ligne |
56 | 7 | Julien Enselme | <pre>127.0.0.1 assos.centrale-marseille.fr</pre> |
57 | 11 | Julien Enselme | |
58 | 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 si oui ou non elle a un vhost qui la concerne). On peut vérifier avec le module Firefox _show ip_ qui donne l’IP du site sur lequel on ai. |
||
59 | 7 | Julien Enselme | |
60 | 1 | Florent Torregrosa | h2. Pouvoir créer des vhost à la pelle |
61 | |||
62 | Exemple : créer le domaine titi.local |
||
63 | |||
64 | * Pour les distributions basées sur Debian |
||
65 | * Pour Mageia 3 |
||
66 | * Pour Fedora |
||
67 | |||
68 | 7 | Julien Enselme | * Exemple : créer deux domaines assos.fun.local et titi.local |
69 | Exemple pour titi.local : |
||
70 | |||
71 | * dans /etc/apache2/sites-available/ créer un fichier titi. Le contenu de titi est : |
||
72 | |||
73 | <pre> |
||
74 | <VirtualHost *:80> |
||
75 | ServerAdmin webmaster@localhost |
||
76 | ServerName titi.local |
||
77 | ServerAlias titi.local |
||
78 | |||
79 | DocumentRoot /chemin/dossier_site |
||
80 | |||
81 | <Directory /chemin/dossier_site/> |
||
82 | Options Indexes FollowSymLinks MultiViews |
||
83 | AllowOverride All |
||
84 | Order allow,deny |
||
85 | allow from all |
||
86 | </Directory> |
||
87 | |||
88 | ErrorLog ${APACHE_LOG_DIR}/titi.error.log |
||
89 | |||
90 | # Possible values include: debug, info, notice, warn, error, crit, |
||
91 | # alert, emerg. |
||
92 | LogLevel warn |
||
93 | |||
94 | CustomLog ${APACHE_LOG_DIR}/titi.access.log combined |
||
95 | </VirtualHost> |
||
96 | </pre> |
||
97 | |||
98 | * créer le fichier test.html dans /chemin/dossier_site et mettre dedans <pre><h1>TITI</h1></pre> |
||
99 | * ajouter un lien symbolique dans /etc/apache2/sites-enabled qui pointe sur le fichiet titi qui est dans /etc/apache2/sites-available/ |
||
100 | |||
101 | * <code>cd /etc/apache2/sites-enabled/</code> |
||
102 | * <code>ln -s ../sites-available/titi .</code> |
||
103 | * ajouter l’entrée titi.local dans le fichier /etc/hosts |
||
104 | <pre> |
||
105 | 127.0.0.1 titi.local |
||
106 | </pre> |
||
107 | |||
108 | * Redémarrer apache : <code>sudo service apache2 restart</code> |
||
109 | * Consulter titi.local/test.html |
||
110 | |||
111 | 1 | Florent Torregrosa | h2. Pouvoir reproduire en local un site en particulier |
112 | |||
113 | * pouvoir télécharger en local juste le minimum de fichiers. Le minimum c’est : |
||
114 | |||
115 | * tout le htmltest sauf le dossier sites |
||
116 | * dans sites/ il faut ne prendre que le dossier default et le dossier du site qui nous concerne. |
||
117 | 14 | 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. |
118 | 1 | Florent Torregrosa | |
119 | 7 | Julien Enselme | * sur sa machine : se faire un dossier d6 et un dossier d7 |
120 | 14 | Julien Enselme | * _Exemple pour le site des annales, à apapter_ : |
121 | <pre> |
||
122 | <code>cd d6</code> |
||
123 | <code>rsync -lr --exclude sites assos@sas1.centrale-marseille.fr:html/* .</code> |
||
124 | <code>mkdir sites</code> |
||
125 | <code>cd sites</code> |
||
126 | <code>rsync -lr assos@sas1.centrale-marseille.fr:html/sites/default .</code> |
||
127 | <code>rsync -lr assos@sas1.centrale-marseille.fr:html/sites/assos.centrale-marseille.fr.annales .</code> (étape longue) |
||
128 | </pre> |
||
129 | 7 | Julien Enselme | |
130 | 1 | Florent Torregrosa | h2. Pouvoir télécharger la base de donnée d’un seul site en particulier |
131 | 2 | Florent Torregrosa | |
132 | 1 | Florent Torregrosa | * savoir faire ça avec phpmyadmin, dans phpmyadmin : |
133 | > * exporter |
||
134 | > * options personnalisées |
||
135 | > * choisir que les tables qui vous intéressent |
||
136 | > * laisser les autres options |
||
137 | > * enregistrer |
||
138 | > * ça enregistre dans votre dossier de téléchargements sur votre machine |
||
139 | 2 | Florent Torregrosa | |
140 | 1 | Florent Torregrosa | * savoir le faire avec drush car parfois le fichier téléchargé par phpmyadmin est trop gros |
141 | |||
142 | > * sur le sas : |
||
143 | 7 | Julien Enselme | > > <pre>dump_site annales (pour une base de données isolée, se placer dans le dossier du site puis drush sql-dump > nom_du_fichier.sql) |
144 | 1 | Florent Torregrosa | cd Desktop/dump_individuels</pre> |
145 | 4 | Florent Torregrosa | |
146 | 1 | Florent Torregrosa | > * sur sa machine : |
147 | > > </pre>@scp assos@sas1.centrale-marseille.fr:Desktop/dump_individuels/annales....</pre> |
||
148 | |||
149 | h2. Monter un site en local |
||
150 | |||
151 | * monter un seul vhost pour assos.centrale-marseille.fr (il sera valable pour tous les sous sites, il ne sera jamais édité) |
||
152 | * télécharger les fichiers et la base de donnée du site en question |
||
153 | * injecter la dbb en local (utiliser le phpmyadmin en local ou sudo mysql -u root -pmotdepasse nomdelabase < fichier.sql) |
||
154 | 7 | Julien Enselme | * modifier le settings.php du site en question pour donner les informations de connection mysql et modifier $base_url |
155 | * pour aller plus vite, renommer le dossier du site en default |
||
156 | 1 | Florent Torregrosa | |
157 | 13 | Julien Enselme | h2. Installer le script drush de mise à jour |
158 | 1 | Florent Torregrosa | |
159 | 13 | Julien Enselme | * suivre la procédure d’installation donnée "ici":http://drupal.org/project/drush_sup |
160 | 1 | Florent Torregrosa | * critère de validation : la commande suivante marche : drush sup |
161 | |||
162 | h2. Exécuter correctement le script de mise à jour |
||
163 | |||
164 | * lire la doc de drush sup |
||
165 | * exécuter drush sup avec les bons arguments |
||
166 | 7 | Julien Enselme | |
167 | h2. Alias drush |
||
168 | |||
169 | |||
170 | TODO (dans la doc drush ?) |
||
171 | installer dom, xml (paquet php) |
||
172 | 1 | Florent Torregrosa | |
173 | 3 | Florent Torregrosa | h1. Annexe : Nom de domaine |
174 | 1 | Florent Torregrosa | |
175 | 5 | Julien Enselme | Normalement, toutes les unix reposent sur le même principe. Ajouter l’entrée suivante dans /etc/hosts : @127.0.0.1 assos.centrale-marseille.fr@ |
176 | 1 | Florent Torregrosa | |
177 | 3 | Florent Torregrosa | h1. Annexe : Vhosts |
178 | 1 | Florent Torregrosa | |
179 | h2. Pour les distributions basées sous Debian |
||
180 | |||
181 | 3 | Florent Torregrosa | * Dans /etc/apache2/sites-available/ créer un fichier titi dont le contenu est : |
182 | <pre> |
||
183 | <VirtualHost *:80> |
||
184 | ServerAdmin webmaster@localhost |
||
185 | ServerName titi.local |
||
186 | ServerAlias titi.local |
||
187 | 2 | Florent Torregrosa | |
188 | 3 | Florent Torregrosa | DocumentRoot /chemin/dossier_site |
189 | 1 | Florent Torregrosa | |
190 | 3 | Florent Torregrosa | <Directory /chemin/dossier_site/> |
191 | Options Indexes FollowSymLinks MultiViews |
||
192 | AllowOverride All |
||
193 | Order allow,deny |
||
194 | allow from all |
||
195 | </Directory> |
||
196 | |||
197 | ErrorLog ${APACHE_LOG_DIR}/titi.error.log |
||
198 | |||
199 | # Possible values include: debug, info, notice, warn, error, crit, |
||
200 | # alert, emerg. |
||
201 | LogLevel warn |
||
202 | |||
203 | CustomLog ${APACHE_LOG_DIR}/titi.access.log combined |
||
204 | |||
205 | </VirtualHost> |
||
206 | </pre> |
||
207 | * créer le fichier test.html dans /chemin/dossier_site et mettre dedans @<h1>TITI</h1>@ |
||
208 | * ajouter un lien symbolique dans /etc/apache2/sites-enabled qui pointe sur le fichier titi qui est dans /etc/apache2/sites-available/ : |
||
209 | > * Manuellement : |
||
210 | 4 | Florent Torregrosa | > <pre> |
211 | 3 | Florent Torregrosa | cd /etc/apache2/sites-enabled/ |
212 | ln -s ../sites-available/titi . |
||
213 | </pre> |
||
214 | > * Avec la commande apache : |
||
215 | 4 | Florent Torregrosa | > <pre> |
216 | 3 | Florent Torregrosa | sudo service a2ensite titi |
217 | </pre> |
||
218 | * ajouter l’entrée titi.local dans le fichier /etc/hosts : |
||
219 | 1 | Florent Torregrosa | <pre> |
220 | @127.0.0.1 titi.local@ |
||
221 | 3 | Florent Torregrosa | </pre> |
222 | 4 | Florent Torregrosa | * restart apache |
223 | 3 | Florent Torregrosa | <pre> |
224 | 4 | Florent Torregrosa | sudo service apache2 restart |
225 | 1 | Florent Torregrosa | </pre> |
226 | * consulter titi.local/test.html |
||
227 | |||
228 | h2. Pour Mageia 3 |
||
229 | 4 | Florent Torregrosa | |
230 | {{warning(la partie pour mageia permet pour l'instant d'atteindre le site via localhost/nom_du_site, pas encore bien connecté avec le fichier Hosts)}} |
||
231 | |||
232 | * Dans /etc/httpd/conf/sites.d/ créer un fichier nom_du_fichier.conf dont le contenu est : |
||
233 | <pre> |
||
234 | # Drupal configuration |
||
235 | Alias /nom_du_site /chemin/dossier_site |
||
236 | |||
237 | <Directory /chemin/dossier_site/> |
||
238 | Require local granted |
||
239 | Options -Indexes +FollowSymlinks +Multiviews |
||
240 | AllowOverride None |
||
241 | |||
242 | # Protect files and directories from prying eyes. |
||
243 | <FilesMatch "\.(engine|inc|info|install|make|module|profile|test|po|sh|.*sql|theme|tpl(\.php)?|xtmpl)$|^(\..*|Entries.*|Repository|Root|Tag|Template)$"> |
||
244 | Order allow,deny |
||
245 | </FilesMatch> |
||
246 | |||
247 | # Don't show directory listings for URLs which map to a directory. |
||
248 | Options -Indexes |
||
249 | |||
250 | # Follow symbolic links in this directory. |
||
251 | Options +FollowSymLinks |
||
252 | |||
253 | # Make Drupal handle any 404 errors. |
||
254 | ErrorDocument 404 /index.php |
||
255 | |||
256 | # Set the default handler. |
||
257 | DirectoryIndex index.php index.html index.htm |
||
258 | |||
259 | # Override PHP settings that cannot be changed at runtime. See |
||
260 | # sites/default/default.settings.php and drupal_environment_initialize() in |
||
261 | # includes/bootstrap.inc for settings that can be changed at runtime. |
||
262 | |||
263 | # PHP 5, Apache 1 and 2. |
||
264 | <IfModule mod_php5.c> |
||
265 | php_flag magic_quotes_gpc off |
||
266 | php_flag magic_quotes_sybase off |
||
267 | php_flag register_globals off |
||
268 | php_flag session.auto_start off |
||
269 | php_value mbstring.http_input pass |
||
270 | php_value mbstring.http_output pass |
||
271 | php_flag mbstring.encoding_translation off |
||
272 | </IfModule> |
||
273 | |||
274 | # Requires mod_expires to be enabled. |
||
275 | <IfModule mod_expires.c> |
||
276 | # Enable expirations. |
||
277 | ExpiresActive On |
||
278 | |||
279 | # Cache all files for 2 weeks after access (A). |
||
280 | ExpiresDefault A1209600 |
||
281 | |||
282 | <FilesMatch \.php$> |
||
283 | # Do not allow PHP scripts to be cached unless they explicitly send |
||
284 | # cache headers themselves. Otherwise all scripts would have to |
||
285 | # overwrite the headers set by mod_expires if they want another |
||
286 | # caching behavior. This may fail if an error occurs early in the |
||
287 | # bootstrap process, and it may cause problems if a non-Drupal PHP |
||
288 | # file is installed in a subdirectory. |
||
289 | ExpiresActive Off |
||
290 | </FilesMatch> |
||
291 | </IfModule> |
||
292 | |||
293 | # Various rewrite rules. |
||
294 | <IfModule mod_rewrite.c> |
||
295 | RewriteEngine on |
||
296 | |||
297 | # Block access to "hidden" directories whose names begin with a period. |
||
298 | # This includes directories used by version control systems such as |
||
299 | # Subversion or Git to store control files. Files whose names begin with |
||
300 | # a period, as well as the control files used by CVS, are protected by |
||
301 | # the FilesMatch directive above. |
||
302 | # |
||
303 | # NOTE: This only works when mod_rewrite is loaded. Without mod_rewrite, |
||
304 | # it is not possible to block access to entire directories from |
||
305 | # .htaccess, because <DirectoryMatch> is not allowed here. |
||
306 | # |
||
307 | # If you do not have mod_rewrite installed, you should remove these |
||
308 | # directories from your webroot or otherwise protect them from being |
||
309 | # downloaded. |
||
310 | RewriteRule "(^|/)\." - [F] |
||
311 | |||
312 | # If your site can be accessed both with and without the 'www.' prefix, |
||
313 | # you can use one of the following settings to redirect users to your |
||
314 | # preferred URL, either WITH or WITHOUT the 'www.' prefix. Choose ONLY |
||
315 | # one option: |
||
316 | # To redirect all users to access the site WITH the 'www.' prefix, |
||
317 | # (http://example.com/... will be redirected to http://www.example.com/...) |
||
318 | # uncomment the following: |
||
319 | # RewriteCond %{HTTP_HOST} !^www\. [NC] |
||
320 | # RewriteRule ^ http://www.%{HTTP_HOST}%{REQUEST_URI} [L,R=301] |
||
321 | # |
||
322 | # To redirect all users to access the site WITHOUT the 'www.' prefix, |
||
323 | # (http://www.example.com/... will be redirected to http://example.com/...) |
||
324 | # uncomment the following: |
||
325 | # RewriteCond %{HTTP_HOST} ^www\.(.+)$ [NC] |
||
326 | # RewriteRule ^ http://%1%{REQUEST_URI} [L,R=301] |
||
327 | |||
328 | # Modify the RewriteBase if you are using Drupal in a subdirectory or in a |
||
329 | # VirtualDocumentRoot and the rewrite rules are not working properly. |
||
330 | # For example if your site is at http://example.com/drupal uncomment and |
||
331 | # modify the following line: |
||
332 | RewriteBase /nom_du_site |
||
333 | # |
||
334 | # If your site is running in a VirtualDocumentRoot at http://example.com/, |
||
335 | # uncomment the following line: |
||
336 | # RewriteBase / |
||
337 | |||
338 | # Pass all requests not referring directly to files in the filesystem to |
||
339 | # index.php. Clean URLs are handled in drupal_environment_initialize(). |
||
340 | RewriteCond %{REQUEST_FILENAME} !-f |
||
341 | RewriteCond %{REQUEST_FILENAME} !-d |
||
342 | RewriteCond %{REQUEST_URI} !=/favicon.ico |
||
343 | RewriteRule ^ index.php [L] |
||
344 | |||
345 | # Rules to correctly serve gzip compressed CSS and JS files. |
||
346 | # Requires both mod_rewrite and mod_headers to be enabled. |
||
347 | <IfModule mod_headers.c> |
||
348 | # Serve gzip compressed CSS files if they exist and the client accepts gzip. |
||
349 | RewriteCond %{HTTP:Accept-encoding} gzip |
||
350 | RewriteCond %{REQUEST_FILENAME}\.gz -s |
||
351 | RewriteRule ^(.*)\.css $1\.css\.gz [QSA] |
||
352 | |||
353 | # Serve gzip compressed JS files if they exist and the client accepts gzip. |
||
354 | RewriteCond %{HTTP:Accept-encoding} gzip |
||
355 | RewriteCond %{REQUEST_FILENAME}\.gz -s |
||
356 | RewriteRule ^(.*)\.js $1\.js\.gz [QSA] |
||
357 | |||
358 | # Serve correct content types, and prevent mod_deflate double gzip. |
||
359 | RewriteRule \.css\.gz$ - [T=text/css,E=no-gzip:1] |
||
360 | RewriteRule \.js\.gz$ - [T=text/javascript,E=no-gzip:1] |
||
361 | |||
362 | <FilesMatch "(\.js\.gz|\.css\.gz)$"> |
||
363 | # Serve correct encoding type. |
||
364 | Header set Content-Encoding gzip |
||
365 | # Force proxies to cache gzipped & non-gzipped css/js files |
||
366 | # separately. |
||
367 | Header append Vary Accept-Encoding |
||
368 | </FilesMatch> |
||
369 | </IfModule> |
||
370 | </IfModule> |
||
371 | |||
372 | </Directory> |
||
373 | </pre> |
||
374 | {{tip(Pour ce fichier de configuration, se baser sur celui fournit par Mageia lors de l'installation d'un Drupal depuis la logithèque de Mageia.)}} |
||
375 | |||
376 | * créer un dossier (avec un Drupal dedans) appelé dossier_site dans /chemin/ |
||
377 | * restart apache |
||
378 | <pre> |
||
379 | sudo service httpd stop |
||
380 | sudo service httpd start |
||
381 | </pre> |
||
382 | |||
383 | * consulter localhost/nom_du_site |
||
384 | |||
385 | 2 | Florent Torregrosa | |
386 | h2. Pour Fedora |