Projet

Général

Profil

Competences techniques apache et drupal » Historique » Version 10

Julien Enselme, 29/05/2013 01:02

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