Projet

Général

Profil

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