Projet

Général

Profil

Scripts et taches planifiees » Historique » Version 20

Florent Torregrosa, 04/08/2013 15:13
ajout des noms des nouveaux scripts

1 1 Julien Enselme
Afin de gagner du temps et d'éviter les erreurs humaines, des scripts ont été écrits tout au long du projet. Certains sont même exécutés automatiquement toutes les semaines.
2 1 Julien Enselme
3 13 Florent Torregrosa
{{>toc}}
4 1 Julien Enselme
5 1 Julien Enselme
h1. Les tâches planifiées
6 1 Julien Enselme
7 3 Julien Enselme
Pour exécuter ces tâches régulièrement, on utilise le "crontab":http://fr.wikipedia.org/wiki/Crontab. Il s'agit d'un programme installé sur notre serveur.
8 1 Julien Enselme
9 3 Julien Enselme
Pour voir et modifier la liste des actions :
10 3 Julien Enselme
# se connecter au serveur : <code>ssh assos@sas1.centrale-marseille</code>
11 3 Julien Enselme
# taper la commande pour voir le crontab <code>crontab -l</code>
12 3 Julien Enselme
# taper la commande pour modifier le crontab <code>crontab -e</code>. /!\ Ne pas effectuer cette opération avant de s'être renseigné sur "vi":http://fr.wikipedia.org/wiki/Vi (l'éditeur de texte utilisé qui n'est pas vraiment intuitif :p) et sur "la syntaxe du crontab":http://fr.wikipedia.org/wiki/Crontab#Modification !
13 3 Julien Enselme
14 1 Julien Enselme
Voici la liste des tâches effectuées régulièrement.
15 1 Julien Enselme
16 3 Julien Enselme
h2. La mise à jour des projets
17 1 Julien Enselme
18 1 Julien Enselme
Voici les différentes étapes réalisées :
19 3 Julien Enselme
# Activer partout le module _update_. C'est lui qui gère la vérification des versions, l'envoi de notifications par mail ainsi que les mises à jour via drush, il est donc indispensable qu'il soit activé.
20 3 Julien Enselme
# Lancer le cron pour que les sites sachent s'il y a des mises à jour à faire
21 1 Julien Enselme
# Supprimer le cache des sites pour réduire drastiquement la taille des bases de données sauvegardées.
22 3 Julien Enselme
# Exécuter le [[Scripts_et_taches_planifiees#dump.sh_and_co|script de sauvegarde des bases de données]]
23 1 Julien Enselme
# Vérifier les versions des projets et au besoin, mettre à jour leur code
24 3 Julien Enselme
# Exécuter la [[Utilisation_de_Drupal_multi-site#Mise_à_jour_de_la_base_de_données|mise à jour des bases de données]]
25 1 Julien Enselme
# Exécuter une nouvelle fois le cron
26 3 Julien Enselme
# Exécuter le [[Scripts_et_taches_planifiees#taille.sh|script de rapport sur la taille utilisée du disque]] et l'envoyer par mail au club Drupal
27 1 Julien Enselme
# Dater les logs et les sauvegarder au bon endroit
28 3 Julien Enselme
# Désactiver le module _update_ (vu qu'il est réactivé avant la mise à jour et que celle-ci a lieu toutes les semaines, il y a peu d'intérêt à le garder activé le reste du temps)
29 1 Julien Enselme
30 3 Julien Enselme
h2. La mise à jour des traductions
31 1 Julien Enselme
32 5 Julien Enselme
Sur les installations d6 et d7 : une fois par semaine le jeudi.
33 1 Julien Enselme
34 1 Julien Enselme
Voici les étapes effectuées :
35 3 Julien Enselme
# Activer partout le module _l10n_update_. C'est lui qui gère la mise à jour des traductions
36 3 Julien Enselme
# Vérifier s'il y a des nouvelles chaînes traduites disponibles
37 3 Julien Enselme
# Ajouter les nouvelles traductions disponibles
38 3 Julien Enselme
# Désactiver le module _l10n_update_
39 1 Julien Enselme
40 3 Julien Enselme
Pour drupal 6, les différentes instructions sont écrites directement dans le crontab. Pour drupal 7, on utilise [[Scripts_et_taches_planifiees#drush_maj_trad|l'alias drush perso <code>drush maj_trad</code>]] dans le crontab.
41 1 Julien Enselme
42 3 Julien Enselme
h2. La réinitialisation des droits d'accès
43 1 Julien Enselme
44 3 Julien Enselme
Sur les installations d6 et d7 : toutes les semaines, après les D&D du club drupal
45 1 Julien Enselme
46 3 Julien Enselme
Cette tâche utilise le script [[Scripts_et_taches_planifiees#ch_mdp|ch_mdp]] afin de rétablir les droits d'accès recommandés par drupal sur 
47 3 Julien Enselme
* les dossiers des sites
48 1 Julien Enselme
* les settings.php des sites
49 1 Julien Enselme
50 3 Julien Enselme
h2. La réinitialisation des variables dangeureuses
51 1 Julien Enselme
52 3 Julien Enselme
Sur l'installation d7 principalement : une fois par semaine
53 1 Julien Enselme
54 3 Julien Enselme
Cette tâche consiste à réinitialiser certaines variables qui donnent des droits considérés comme trop permissifs donc dangereux aux administrateurs des sites. En voici la liste :
55 1 Julien Enselme
<pre>
56 1 Julien Enselme
<code class="bash">
57 1 Julien Enselme
drushall_atest vset error_level 0 --yes
58 1 Julien Enselme
</code>
59 1 Julien Enselme
</pre>
60 1 Julien Enselme
61 1 Julien Enselme
Cette commande permet de ne pas afficher les messages d'erreurs aux utilisateurs autre que les administrateurs. En effet, ils contiennent parfois des informations sensibles sur l'installation et ne doivent donc pas être divulgués à n'importe qui.
62 1 Julien Enselme
<pre>
63 1 Julien Enselme
<code class="php">
64 1 Julien Enselme
drushall_atest php-eval variable_set\(\'allow_authorize_operations\',FALSE\)\;
65 1 Julien Enselme
</code>
66 1 Julien Enselme
</pre>
67 1 Julien Enselme
68 1 Julien Enselme
Cette commande  permet de ne pas autoriser les utilisateurs à installer et mettre à jour des modules via l'interface du site (fonctionnalité introduite dans drupal7). En effet, seul le club Drupal maintient les codes des projet, afin d'en garantir la pérennité.
69 1 Julien Enselme
70 1 Julien Enselme
<pre>
71 1 Julien Enselme
<code class="php">
72 1 Julien Enselme
drushall_atest vset --always-set reverse_proxy TRUE
73 1 Julien Enselme
drushall_atest vset --always-set --format=json reverse_proxy_addresses '["147.94.19.16","147.94.19.17"]'
74 1 Julien Enselme
</code>
75 1 Julien Enselme
</pre>
76 3 Julien Enselme
Ces commandes permettent de déclarer à drupal les serveurs proxy du CRI afin d'éviter qu'il ne répertorie tous les visiteurs comme ayant l'adresse des sus-cités serveurs. **Pas fini : voir http://assos.centrale-marseille.fr/content/t%C3%A2che/d%C3%A9clarer-les-proxy-du-cri-%C3%A0-drupal**
77 1 Julien Enselme
78 3 Julien Enselme
79 1 Julien Enselme
h3. Comment le lancer ?
80 1 Julien Enselme
81 3 Julien Enselme
N'importe où, taper <code>reinit_var.sh</code>.
82 1 Julien Enselme
83 3 Julien Enselme
h2. La sauvegarde des bases de données
84 1 Julien Enselme
85 3 Julien Enselme
Sur les installations d6 et d7 : une fois par semaine
86 1 Julien Enselme
87 6 Julien Enselme
On utilise les [[Scripts_et_taches_planifiees#Tout-sauvegarder|scripts de sauvegarde créés par le club Drupal]].
88 1 Julien Enselme
89 3 Julien Enselme
h2. La purge des sauvegardes de bdd
90 1 Julien Enselme
91 3 Julien Enselme
Sur les installations d6 et d7 : toutes les semaines
92 1 Julien Enselme
93 3 Julien Enselme
Cette tâche utilise le script de [[Scripts_et_taches_planifiees#purge_des_sauvegardes.sh|purge des sauvegardes]] afin de libérer de l'espace disque en supprimant les sauvegardes de bdd les plus vieilles.
94 1 Julien Enselme
95 1 Julien Enselme
h1. Liste des scripts à disposition
96 1 Julien Enselme
97 1 Julien Enselme
Les scripts utilisés sont hébergés dans le répertoire bin du compte assos.
98 1 Julien Enselme
99 20 Florent Torregrosa
h2. all-reset-permissions.sh
100 20 Florent Torregrosa
h2. contrib-usage.sh
101 20 Florent Torregrosa
h2. d6-all-drush.sh
102 20 Florent Torregrosa
h2. d6-all-dump-full.sh
103 20 Florent Torregrosa
h2. d6-all-update-contrib.sh
104 20 Florent Torregrosa
h2. d6-dump-individual.sh
105 20 Florent Torregrosa
h2. d6-reset-variables.sh
106 20 Florent Torregrosa
h2. d7-all-drush-logged.sh
107 20 Florent Torregrosa
h2. d7-all-drush.sh
108 20 Florent Torregrosa
h2. d7-all-dump-full.sh
109 20 Florent Torregrosa
h2. d7-all-dump-individual.sh
110 20 Florent Torregrosa
h2. d7-all-releases-info.sh
111 20 Florent Torregrosa
h2. d7-all-reset-variables.sh
112 20 Florent Torregrosa
h2. d7-all-security-review.sh
113 20 Florent Torregrosa
h2. d7-all-update-contrib.sh
114 20 Florent Torregrosa
h2. d7-all-update-localisation.sh
115 20 Florent Torregrosa
h2. d7-create-site.sh
116 20 Florent Torregrosa
h2. d7-delete-site.sh
117 20 Florent Torregrosa
h2. d7-reset-variables.sh
118 20 Florent Torregrosa
h2. delete-temporary-files.sh
119 20 Florent Torregrosa
h2. disk-usage.sh
120 20 Florent Torregrosa
h2. flush-files.sh
121 20 Florent Torregrosa
h2. flush-full-databases-backups.sh
122 20 Florent Torregrosa
h2. flush-individual-databases-backups.sh
123 20 Florent Torregrosa
h2. scripts-config-site.sh
124 20 Florent Torregrosa
h2. scripts-config.sh
125 20 Florent Torregrosa
h2. scripts-utils.sh
126 20 Florent Torregrosa
127 1 Julien Enselme
h2. ch_mdp
128 1 Julien Enselme
129 11 Julien Enselme
Il a été écrit pour permettre de prendre acte de la modification du mot de passe de la base de données rapidement dans tous les settings.php (pour l’installation de drupal 6 uniquement, les sites drupal 7 étant chacun dans leur base de données).
130 1 Julien Enselme
131 11 Julien Enselme
Pour effectuer cette action, il faut donner l'ancien et le nouveau mot de passe en argument puis lancer le script.
132 1 Julien Enselme
133 3 Julien Enselme
Plus d'info sur comment ça marche en lisant http://fr.wikipedia.org/wiki/Stream_Editor#Utilisation_la_documentation_de_la_commande_sed et les commentaires laissés dans le code du script.
134 1 Julien Enselme
135 1 Julien Enselme
h3. Comment le lancer ?
136 1 Julien Enselme
137 3 Julien Enselme
Il suffit de taper <code>ch_mdp</code> n'importe où dans le compte assos.
138 1 Julien Enselme
139 1 Julien Enselme
h3. À quoi ça ressemble ?
140 1 Julien Enselme
141 1 Julien Enselme
<pre>
142 1 Julien Enselme
<code class="bash">
143 1 Julien Enselme
cd [drupal directory]/sites
144 1 Julien Enselme
145 3 Julien Enselme
for x in $(ls -1 | grep -v 'all'); do
146 3 Julien Enselme
	cd $x;
147 3 Julien Enselme
	fichier="settings.php" 
148 1 Julien Enselme
	chmod 600 $fichier
149 1 Julien Enselme
	mv $fichier $fichier.old
150 15 Julien Enselme
        #remplacer la première chaine après le / par l'ancien mot de passe, et la seconde chaine (après le deuxième /) par le nouveau mot de passe
151 11 Julien Enselme
	sed "s/$1/$2/g" < $fichier.old > $fichier
152 1 Julien Enselme
	chmod 400 $fichier
153 15 Julien Enselme
	echo "Verifier que le site fonctionne et appuyer sur la touche Entree pour continuer"
154 15 Julien Enselme
	read fake_variable
155 1 Julien Enselme
	rm $fichier.old
156 1 Julien Enselme
	cd ..
157 15 Julien Enselme
done
158 11 Julien Enselme
</code>
159 11 Julien Enselme
</pre>
160 11 Julien Enselme
161 11 Julien Enselme
h2. chk_perm
162 11 Julien Enselme
163 11 Julien Enselme
Ce script rétablit les permissions des dossiers des sites, des scripts et des settings.php. Il se lance tous les jours grâce au cron.
164 11 Julien Enselme
165 11 Julien Enselme
Il ressemble à ça :
166 11 Julien Enselme
<pre>
167 11 Julien Enselme
<code class="bash">
168 11 Julien Enselme
cd [drupal directory]/sites
169 11 Julien Enselme
170 11 Julien Enselme
for dir in $(find . -type d -maxdepth 1 ! -name all)
171 11 Julien Enselme
do
172 11 Julien Enselme
    chmod 755 $dir
173 11 Julien Enselme
    cd $dir
174 11 Julien Enselme
    chmod 400 settings.php
175 11 Julien Enselme
    cd -
176 11 Julien Enselme
done
177 1 Julien Enselme
</code>
178 1 Julien Enselme
</pre>
179 1 Julien Enselme
180 1 Julien Enselme
h2. dis_tiers.sh et en_tiers.sh
181 1 Julien Enselme
182 3 Julien Enselme
Créé en juillet 2011 dans le cadre de [[De_Drupal6_vers_Drupal7|la migration de d6 à d7]], ces scripts permettent respectivement de désactiver et réactiver tous les modules tiers (c'est-à-dire les modules qui ne font pas partie du noyau / core de drupal, ceux qui sont installé dans sites/all/modules).
183 1 Julien Enselme
184 1 Julien Enselme
En effet, il s'agit de deux étapes indipensables pour la migration d'un site.
185 1 Julien Enselme
186 1 Julien Enselme
h3. Comment les lancer ?
187 1 Julien Enselme
188 1 Julien Enselme
Il suffit de taper "dis_tiers.sh" ou "en_tiers.sh" dans le dossier du site en question.
189 1 Julien Enselme
190 1 Julien Enselme
h3. À quoi ça ressemble ?
191 1 Julien Enselme
192 1 Julien Enselme
<pre>
193 1 Julien Enselme
<code class="bash">
194 1 Julien Enselme
##dis_tiers.sh
195 1 Julien Enselme
#écrire le nom des modules non core dans un fichier
196 1 Julien Enselme
drush pml |grep -v Core* | grep Module | grep Enabled > fichier.temp
197 1 Julien Enselme
sed -e 's/\(.*(\)\(.*\)\().*\)/\2/' fichier.temp > modules_tiers.txt
198 1 Julien Enselme
#désactiver ces modules
199 1 Julien Enselme
for line in $(cat modules_tiers.txt); do drush dis -y "$line" ; done  
200 1 Julien Enselme
#effacer les fichiers créés
201 1 Julien Enselme
rm fichier.temp
202 1 Julien Enselme
203 1 Julien Enselme
##en_tiers.sh
204 1 Julien Enselme
#activer ces modules du fichier texte
205 1 Julien Enselme
for line in $(cat modules_tiers.txt); do drush en -y "$line" ; done 
206 1 Julien Enselme
</code>
207 1 Julien Enselme
</pre>
208 1 Julien Enselme
209 1 Julien Enselme
NB : dis_tiers.sh crée un fichier texte contenant la liste des modules tiers qui étaient activés sur le site. Il faut donc :
210 3 Julien Enselme
* Avoir des droits d'écriture sur le dossier du site pour l'exécuter
211 3 Julien Enselme
* Penser à supprimer ce fichier et à remettre les droits correctement (par exemple en lançant le script [[Scripts_et_taches_planifiees#ch_mdp|ch_mdp ]]) après.
212 1 Julien Enselme
213 1 Julien Enselme
h2. drushall and co
214 1 Julien Enselme
215 1 Julien Enselme
Pour administrer tous les sites du multi-site en une seule fois, nous avons créé un script à partir de drush.
216 1 Julien Enselme
Il s'utilise comme drush, mais effectue la commande drush tapée sur tous les sites de l'installation un par un.
217 1 Julien Enselme
218 1 Julien Enselme
h3. Comment on le lance ?
219 1 Julien Enselme
220 1 Julien Enselme
Sur l'installation d6, on lance <code>drushall</code> n'importe où.
221 1 Julien Enselme
222 1 Julien Enselme
Sur l'installation d7, on lance <code>drushall_atest</code> n'importe où.
223 1 Julien Enselme
224 1 Julien Enselme
h3. À quoi ça ressemble ?
225 1 Julien Enselme
226 1 Julien Enselme
<pre>
227 1 Julien Enselme
<code class="bash">
228 1 Julien Enselme
#~/bin/sh
229 1 Julien Enselme
# si pas d'arguments :
230 1 Julien Enselme
if [ $# -lt 1 ]; then
231 1 Julien Enselme
  echo "usage: $0 <drush args>"
232 1 Julien Enselme
  exit 1
233 1 Julien Enselme
fi
234 1 Julien Enselme
235 1 Julien Enselme
cd [drupal directory]/sites
236 1 Julien Enselme
237 1 Julien Enselme
for x in $(ls -1 | grep -v 'all'); do
238 1 Julien Enselme
  if [ -d $x -a ! -L $x ]; then
239 1 Julien Enselme
    cd $x;
240 1 Julien Enselme
    echo $x
241 1 Julien Enselme
    drush $*
242 1 Julien Enselme
    cd -;
243 1 Julien Enselme
  fi
244 1 Julien Enselme
done
245 1 Julien Enselme
</code>
246 1 Julien Enselme
</pre>
247 1 Julien Enselme
248 1 Julien Enselme
h2. drushcronone
249 1 Julien Enselme
250 1 Julien Enselme
h3. Histoire
251 1 Julien Enselme
252 3 Julien Enselme
Ce script a été introduit pour la version 6 du projet essentiellement pour améliorer les performances : au lieu de faire un wget sur le cron.php d'un site, valait mieux exécuter le script _en interne_.
253 1 Julien Enselme
254 1 Julien Enselme
h3. Besoin
255 1 Julien Enselme
256 1 Julien Enselme
La version 7 du projet en a besoin plus que jamais ! puisque le cron.php n'est plus 'wget'able sans une chaîne de codes à ajouter à l'url publique, sinon il faut avoir les droits nécessaires.
257 1 Julien Enselme
258 1 Julien Enselme
h3. Usage
259 1 Julien Enselme
260 1 Julien Enselme
Donc pour exécuter le cron pour un seul site, il suffit de donner le nom du répertoire.
261 3 Julien Enselme
Exemple : <code>drushcronone assos.centrale-marseille.fr.cac13</code>
262 1 Julien Enselme
263 1 Julien Enselme
Q : Où est ce que ce script est le plus utilisé ?
264 1 Julien Enselme
265 1 Julien Enselme
R : Dans les tâches planifiés (crontab) bien sûr !
266 1 Julien Enselme
267 8 Julien Enselme
h2. dump.sh and co
268 1 Julien Enselme
269 8 Julien Enselme
Tous ces scripts se lancent n'importe où.
270 1 Julien Enselme
271 8 Julien Enselme
h3. Dump pour drupal 6
272 3 Julien Enselme
273 8 Julien Enselme
h4. Sauvegarder uniquement les tables d'un site
274 8 Julien Enselme
275 1 Julien Enselme
On a créé des scripts qui permettent de sauvegarder uniquement les tables associés à un site (et non toute la base).
276 3 Julien Enselme
277 3 Julien Enselme
Ils se lancent n'importe où (mais attention, la sauvegarde est effectuée là où il est lancé, donc à ne pas lancer dans dossier accessible par n'importe qui !) en tapant <code>dump_site nom_de_site</code> (d6) ou <code>dump_site_atest nom_du_site</code> (d7). Le nom du site à fournir est le préfixe utilisé dans la base de données.
278 3 Julien Enselme
279 3 Julien Enselme
Ils **ressemblent** à :
280 1 Julien Enselme
<pre>
281 1 Julien Enselme
<code class="bash">
282 1 Julien Enselme
#récupération des tables du site dans le fichier liste_tables.temp
283 1 Julien Enselme
tables='_%'
284 1 Julien Enselme
liste="$1$tables"
285 1 Julien Enselme
286 1 Julien Enselme
mysql -h serveur -u utilisateur --password=super_mot-de-passe -BNe "show tables like '"$liste"'" base_de_données | tr '\r\n' ' ' > liste_tables.temp
287 1 Julien Enselme
288 1 Julien Enselme
#transformation de cette liste en une variable
289 1 Julien Enselme
var=$(cat liste_tables.temp)
290 1 Julien Enselme
291 1 Julien Enselme
#sauvegarde de toutes ces tables
292 1 Julien Enselme
suffixe="_dump.sql"
293 1 Julien Enselme
fichier="$1$suffixe"
294 1 Julien Enselme
295 1 Julien Enselme
mysqldump base_de_données -h serveur -u utilisateur --password=super_mot-de-passe $var > $fichier
296 1 Julien Enselme
297 1 Julien Enselme
#suppression du fichier temporaire utilisé
298 1 Julien Enselme
rm liste_tables.temp
299 1 Julien Enselme
</code>
300 1 Julien Enselme
</pre>
301 1 Julien Enselme
302 8 Julien Enselme
h4. Tout sauvegarder
303 1 Julien Enselme
304 3 Julien Enselme
Pour drupal 6, on a un script qui réalise la sauvegarde de toute la base en une seule fois : <code> dump.sh</code>. Il **ressemble** à ça :
305 1 Julien Enselme
<pre>
306 1 Julien Enselme
<code class="bash">
307 1 Julien Enselme
mysqldump nom_de_la_base -h serveur -u utilisateur --password=super_mot_de_passe_trop_bien > ~/chemin_vers_la/sauvegarde.dump.sql
308 1 Julien Enselme
</code>
309 1 Julien Enselme
</pre>
310 1 Julien Enselme
311 8 Julien Enselme
h3. Dump pour drupal 7
312 1 Julien Enselme
313 8 Julien Enselme
Pour drupal 7, on a un script plus complet : <code>dump_site_atest_all</code> qui repose sur @drush sql-dump@ :
314 1 Julien Enselme
315 8 Julien Enselme
<pre>
316 8 Julien Enselme
<code class="bash">
317 8 Julien Enselme
#!/bin/sh
318 8 Julien Enselme
PATH=/usr/local/bin:/usr/bin:/bin:/users/guest/assos/bin
319 8 Julien Enselme
320 8 Julien Enselme
sites_dir=~/htmltest/sites
321 8 Julien Enselme
backup_dir=~/Desktop/dump_d7
322 8 Julien Enselme
date=`date "+%Y-%m-%d-%Hh%Mm%Ss"`
323 8 Julien Enselme
324 8 Julien Enselme
cd $sites_dir
325 8 Julien Enselme
326 8 Julien Enselme
#Cherche dans le sous répertoire du répertoire courant sauf dans le sous répertoire
327 8 Julien Enselme
# all et dans les liens.
328 8 Julien Enselme
for dir in $(find . -maxdepth 1 -mindepth 1 -type d ! -name all )
329 8 Julien Enselme
do
330 8 Julien Enselme
    cd $dir
331 8 Julien Enselme
    drush sql-dump --result-file="$backup_dir/$dir.dump$date.sql"
332 8 Julien Enselme
    cd -
333 8 Julien Enselme
done
334 8 Julien Enselme
</code>
335 8 Julien Enselme
</pre>
336 8 Julien Enselme
337 8 Julien Enselme
Ce script s’exécute une fois par semaine.
338 1 Julien Enselme
339 1 Julien Enselme
h2. maj.sh
340 1 Julien Enselme
341 3 Julien Enselme
Ce script est principalement constitué d'une suite de commandes drush et d'appels à d'autres scripts du projet.
342 1 Julien Enselme
343 3 Julien Enselme
Plus d'info sur les étapes précises dans les commentaires du script lui-même et dans le [[Scripts_et_taches_planifiees#la_mise_à_jour_des_projets|paragraphe suivant]].
344 1 Julien Enselme
345 1 Julien Enselme
h3. Comment le lancer ?
346 1 Julien Enselme
347 1 Julien Enselme
<code>maj.sh</code> ou <code>maj_d7.sh</code>, n'importe où.
348 1 Julien Enselme
349 3 Julien Enselme
NB : il faut que le module _update_ soit activé sur tous les sites de l'installation pour que ce script fonctionne.
350 1 Julien Enselme
351 1 Julien Enselme
h2. usep
352 1 Julien Enselme
353 3 Julien Enselme
Ce script a été créé dans le cadre de la [[De_Drupal6_vers_Drupal7|migration de drupal 6 à drupal 7]] mais peut être utilisé pour des tas de choses : il permet de savoir quels sont les sites qui utilisent (c'est-à-dire qui ont activé) un projet donné.
354 1 Julien Enselme
355 3 Julien Enselme
Pour le moment, il n'est fonctionnel que pour drupal 6, mais peut être adapté sans mal à drupal 7.
356 3 Julien Enselme
357 1 Julien Enselme
h3. Comment le lancer ?
358 1 Julien Enselme
359 1 Julien Enselme
Taper <code>usep projet</code> dans n'importe quel dossier de site de l'installation drupal 6.
360 1 Julien Enselme
361 1 Julien Enselme
h3. À quoi ça ressemble ?
362 1 Julien Enselme
363 1 Julien Enselme
(quelques  commentaires sont également dispo directement dans le script pour mieux comprendre son fonctionnement)
364 1 Julien Enselme
<pre>
365 1 Julien Enselme
<code class="bash">
366 1 Julien Enselme
#si pas d'argument donnés :
367 1 Julien Enselme
if [ $# -lt 1 ]; then
368 1 Julien Enselme
  echo "usage: $0 <drush args>"
369 1 Julien Enselme
  exit 1
370 1 Julien Enselme
fi
371 1 Julien Enselme
372 1 Julien Enselme
373 1 Julien Enselme
cd [drupal_directory]/sites
374 1 Julien Enselme
375 1 Julien Enselme
376 1 Julien Enselme
for x in $(ls -1 | grep -v 'all' | grep -v file-*); do
377 1 Julien Enselme
  if [ -d $x -a ! -L $x ]; then
378 1 Julien Enselme
    cd $x;
379 1 Julien Enselme
    if [ 1 = `drush pml --no-core --status=enabled | grep $1 | wc -l` ]; then
380 1 Julien Enselme
             echo $x; 
381 1 Julien Enselme
            fi
382 1 Julien Enselme
    cd -;
383 1 Julien Enselme
  fi
384 1 Julien Enselme
done
385 1 Julien Enselme
</code>
386 1 Julien Enselme
</pre>
387 1 Julien Enselme
388 3 Julien Enselme
h2. Taille.sh
389 1 Julien Enselme
390 1 Julien Enselme
Ce script utilise la commande <code>du -hcs</code> pour retourner l'espace disque utilisé sur le compte assos, ainsi que sa répartition dans les différents répertoires des sites).
391 1 Julien Enselme
392 1 Julien Enselme
Ce script est notamment utilisé à la fin du script de mise à jour de projet ; son résultat est envoyé par mail au club drupal pour vérification.
393 1 Julien Enselme
394 1 Julien Enselme
h2. init_var.sh
395 1 Julien Enselme
396 1 Julien Enselme
Ce script permet d'initialiser des configurations et variables dangereuses, pour l'installation drupal 7. Il faut le lancer après chaque installation de sous-site.
397 1 Julien Enselme
398 1 Julien Enselme
h3. Comment le lancer ?
399 1 Julien Enselme
400 1 Julien Enselme
Taper <code>init_var.sh</code> (ou <code>drush init</code>) dans le dossier du site.
401 1 Julien Enselme
402 1 Julien Enselme
h3. À quoi ça ressemble ?
403 1 Julien Enselme
404 1 Julien Enselme
<pre>
405 1 Julien Enselme
<code class="bash">
406 1 Julien Enselme
drush vset error_level 0 --yes
407 1 Julien Enselme
</code>
408 1 Julien Enselme
</pre>
409 1 Julien Enselme
410 1 Julien Enselme
Cette commande permet de ne pas afficher les messages d'erreurs aux utilisateurs autre que les administrateurs. En effet, ils contiennent parfois des informations sensibles sur l'installation et ne doivent donc pas être divulguées à n'importe qui.
411 1 Julien Enselme
412 1 Julien Enselme
<pre>
413 1 Julien Enselme
<code class="php">
414 1 Julien Enselme
drush php-eval variable_set\(\'allow_authorize_operations\',FALSE\)\; 
415 1 Julien Enselme
</code>
416 1 Julien Enselme
</pre>
417 1 Julien Enselme
418 1 Julien Enselme
Cette commande  permet de ne pas autoriser les utilisateurs à installer et mettre à jour des modules via l'interface du site (fonctionnalité introduite dans drupal7). En effet, seul le club Drupal maintient les codes des projet, afin d'en garantir la pérennité.
419 1 Julien Enselme
420 1 Julien Enselme
<pre>
421 1 Julien Enselme
<code class="bash">
422 1 Julien Enselme
drush vset --always-set reverse_proxy TRUE
423 1 Julien Enselme
drush vset --always-set --format=json reverse_proxy_addresses '["147.94.19.16","147.94.19.17"]'
424 1 Julien Enselme
</code>
425 1 Julien Enselme
</pre>
426 1 Julien Enselme
427 1 Julien Enselme
Ces commandes permettent de déclarer à drupal les serveurs proxy du CRI afin d'éviter qu'il ne répertorie tous les visiteurs comme ayant l'adresse des sus-cités serveurs. Pour plus d'info, voir le mail de dgeo du 15 mai 2012.
428 1 Julien Enselme
<pre>
429 4 Julien Enselme
<code>
430 1 Julien Enselme
drush ev "variable_set('update_notify_emails', array('coucouuu@example.com'));"
431 1 Julien Enselme
</code>
432 1 Julien Enselme
</pre>
433 1 Julien Enselme
434 3 Julien Enselme
Cette commande permet de modifier l'adresse de la personne qui recevra des notifications lorsqu'une nouvelle mise à jour (projet ou noyau drupal) est disponible (NB : c'est le module (du noyau) _update_ qui gère ces envois, s'il est désactivé, aucune vérification des versions n'est effectuée)
435 1 Julien Enselme
Pour ne pas déranger les webmasters avec ceci, il faut mettre l'adresse du club drupal.
436 1 Julien Enselme
437 1 Julien Enselme
h2. reinit_var.sh
438 1 Julien Enselme
439 1 Julien Enselme
Ce script est utilisé pour réinitialiser des configurations et variables dangereuses sur tous les sites.
440 1 Julien Enselme
441 3 Julien Enselme
Des informations détaillées sont disponibles dans [[Scripts_et_taches_planifiees#la_réinitialisation_des_variables_dangeureuses|ce paragraphe]].
442 3 Julien Enselme
443 1 Julien Enselme
h3. Comment le lancer ?
444 1 Julien Enselme
445 1 Julien Enselme
Taper <code>reinit_var.sh</code> n'importe où.
446 1 Julien Enselme
447 1 Julien Enselme
h2. purge_des_sauvegardes.sh
448 1 Julien Enselme
449 1 Julien Enselme
Ce script permet de supprimer les vieilles sauvegardes de base de données, afin de libérer de l'espace disque.
450 1 Julien Enselme
451 1 Julien Enselme
Le script nettoie les sauvegardes de sites individuels et les sauvegardes des bases de données complètes d6 et d7.
452 1 Julien Enselme
453 1 Julien Enselme
h3. Comment le lancer ?
454 1 Julien Enselme
455 3 Julien Enselme
Il suffit de taper <code>purge_des_sauvegardes.sh</code> n'importe où dans le compte assos.
456 1 Julien Enselme
457 1 Julien Enselme
h3. À quoi ça ressemble ?
458 1 Julien Enselme
459 1 Julien Enselme
<pre>
460 1 Julien Enselme
<code class="bash">
461 1 Julien Enselme
cd [dump directory]
462 1 Julien Enselme
463 1 Julien Enselme
if [ $(ls -l | wc -l)  -gt YY ] ; then # s'il y a plus de YY fichiers alors
464 1 Julien Enselme
465 1 Julien Enselme
ls -tr | head -XX | xargs rm; #supprime les XX fichiers les plus vieux
466 1 Julien Enselme
467 1 Julien Enselme
else # sinon, alerte
468 1 Julien Enselme
469 1 Julien Enselme
echo "mon message d'erreur" | mail -s "[dump assos] mon message d'erreur" assos@centrale-marseille.fr ;
470 1 Julien Enselme
471 1 Julien Enselme
fi
472 1 Julien Enselme
</code>
473 1 Julien Enselme
</pre>
474 1 Julien Enselme
475 7 Julien Enselme
{{important(Ce script supprime les x sauvegardes les plus vieilles de chaque catégorie (sites d7, tout d6, tout d7), sans aucune notion de temps. Cela implique que si des sauvegardes ont été faites manuellement, des sauvegardes automatiques plus vieilles seront supprimées (alors qu'elles ne sont pas nécessairement périmées !))}}
476 1 Julien Enselme
477 10 Florent Torregrosa
h2. drushall_atest_logged
478 9 Florent Torregrosa
479 9 Florent Torregrosa
Pour faire des commandes drush et quelles soient logguées par site dans le dossier Desktop/log/d7/nom_du_site.log
480 9 Florent Torregrosa
481 14 Julien Enselme
h1. Anciennes entrées du crontab
482 14 Julien Enselme
483 14 Julien Enselme
Ces entrées ne sont plus nécessaires mais conservées pour archive :
484 14 Julien Enselme
485 16 Julien Enselme
* 03 03 * * *     /users/guest/assos/bin/drushall cron
486 16 Julien Enselme
* * */23 * * * echo "le crontab sas1 fonctionne, supprimer celui de scylla mnt !" | mail -s "sas1 is talking to you" assos