Projet

Général

Profil

Competences techniques apache et drupal » Historique » Version 6

Julien Enselme, 15/05/2013 23:42
Infos doublon

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