Projet

Général

Profil

MigrationAppliEnvole4 » Historique » Version 21

Lionel Morin, 08/07/2013 14:25

1 1 Lionel Morin
h1. Migration d'une application Envole vers la version EOLE 2.4 (ébauche)
2 1 Lionel Morin
3 3 Lionel Morin
Pour faciliter le travail de packaging, il est nécessaire de [[eole-skeletor:Doc-geting-started| "skeletoriser"]] le dépot 2.3 pour le [[eole:EoleDebianPackaging24| transformer en dépot 2.4]].
4 5 Lionel Morin
5 13 Lionel Morin
h2. Nouvelle organisation du dépot git
6 1 Lionel Morin
7 13 Lionel Morin
Une nouvelle organisation globale des dépots git pour Envole est mise en place et sera commune pour 2.3 et 2.4.
8 13 Lionel Morin
9 13 Lionel Morin
h3. Description des branches
10 13 Lionel Morin
11 8 Lionel Morin
|_.Sources originales |_.Sources modifiées pour Envole |_.Ajouts EOLE  |_.Packaging      |
12 13 Lionel Morin
|/2=.upstream         |/2=.=>  patch                   |/2=.=>  master |=>  packaging 2.3|
13 1 Lionel Morin
|                                                                       =>  packaging 2.4|
14 4 Lionel Morin
15 15 Lionel Morin
* la branche _*upstream*_ ne contient que les sources originales de l'application et sert de référence pour la branche patch
16 13 Lionel Morin
* la branche _*patch*_ contient les sources patchées pour envole (il y a ici possibilité de générer un paquet envole-<nom_appli>)
17 1 Lionel Morin
* la branche _*master*_ est commune en 2.3 et 2.4 (sous réserve de rester compatible) et comporte, en plus des sources, tous les ajouts EOLE (templates, dicos, scripts, sql, password...)
18 14 Lionel Morin
* les branches de *_packaging_*, une par version
19 21 Lionel Morin
Les flèches "=>" représentent le sens de merge des branches. (*uptream* est mergée dans *patch* qui est mergée dans *master* qui est mergée dans *packaging*)
20 13 Lionel Morin
21 13 Lionel Morin
h3. Étapes de migration d'un dépot
22 13 Lionel Morin
23 14 Lionel Morin
# Créer la branche "patch" à partir de "master" :
24 13 Lionel Morin
<pre>
25 14 Lionel Morin
user:~/depot/monappli (master)$ git checkout -b patch
26 1 Lionel Morin
</pre>
27 1 Lionel Morin
# Supprimer tout le contenu autre que le dossier src :
28 14 Lionel Morin
<pre>
29 16 Lionel Morin
user:~/depot/monappli (patch)$ git rm -r dicos/* sso/* tmpl/* sql/* Makefile eole.mk apps.mk # etc...
30 14 Lionel Morin
</pre>
31 14 Lionel Morin
# Commiter
32 14 Lionel Morin
<pre>
33 14 Lionel Morin
user:~/depot/monappli (patch)$ git commit -m "Suppression de la partie EOLE"
34 14 Lionel Morin
</pre>
35 17 Lionel Morin
# Créer la branche "upstream" à partir de "patch" :
36 17 Lionel Morin
<pre>
37 17 Lionel Morin
user:~/depot/monappli (patch)$ git checkout -b upstream
38 17 Lionel Morin
</pre>
39 17 Lionel Morin
# Supprimer toutes les sources du dossier src :
40 17 Lionel Morin
<pre>
41 17 Lionel Morin
user:~/depot/monappli (upstream)$ git rm -r src/monappli-1.0.0/* src/plugins-1.0.0/* # etc...
42 17 Lionel Morin
</pre>
43 17 Lionel Morin
# Télécharger les sources de l'application depuis le site d'origine (fichier tar.gz)
44 17 Lionel Morin
# Décompresser les sources dans le dossier src et renommer le dossier selon la nomenclature skeletor :
45 17 Lionel Morin
<pre>
46 18 Lionel Morin
user:~/depot/monappli (upstream)/src$ tar -xvzf ~/monappli-1.0.0.tar.gz 
47 18 Lionel Morin
user:~/depot/monappli (upstream)$ mv monappli monappli-1.0.0
48 17 Lionel Morin
</pre>
49 19 Lionel Morin
# Commiter
50 19 Lionel Morin
<pre>
51 19 Lionel Morin
user:~/depot/monappli (upstream)$ git commit -m "Mise en place des sources 1.0.0"
52 19 Lionel Morin
</pre>
53 19 Lionel Morin
# Merge de la branche "upstream" dans "patch" (avec une option pour conserver les fichiers de "patch") :
54 19 Lionel Morin
<pre>
55 19 Lionel Morin
user:~/depot/monappli (upstream)$ git checkout patch
56 19 Lionel Morin
user:~/depot/monappli (patch)$ git merge -s ours upstream
57 19 Lionel Morin
</pre>
58 19 Lionel Morin
# Merge de la branche "patch" dans "master" (avec une option pour conserver les fichiers de "master") :
59 19 Lionel Morin
<pre>
60 19 Lionel Morin
user:~/depot/monappli (patch)$ git checkout master
61 19 Lionel Morin
user:~/depot/monappli (master)$ git merge -s ours patch
62 19 Lionel Morin
</pre>
63 1 Lionel Morin
64 20 Lionel Morin
Les options de merge étant conservées donc les prochains merge pourront se faire avec un simple "@git merge ...@".
65 20 Lionel Morin
Il est important de bien respecter le flux de merge des branches (représenté par "=>" dans le tableau au-dessus).
66 20 Lionel Morin
67 20 Lionel Morin
68 1 Lionel Morin
h2. Modification des dicos
69 1 Lionel Morin
70 1 Lionel Morin
Normalement il n'y a rien à changer.
71 1 Lionel Morin
72 1 Lionel Morin
h2. Modification des templates
73 1 Lionel Morin
74 1 Lionel Morin
Certaines variables souvent utilisées dans Envole ont changé de nom.
75 1 Lionel Morin
76 1 Lionel Morin
|_.Nom en 2.3                  |_.Nouveau nom en 2.4          |
77 1 Lionel Morin
|adresse_ip_annuaire           |container_ip_annuaire         |
78 1 Lionel Morin
|adresse_ip_fichier            |container_ip_fichier          |
79 1 Lionel Morin
|adresse_ip_mail               |container_ip_mail             |
80 1 Lionel Morin
|adresse_ip_mysql              |container_ip_mysql            |
81 1 Lionel Morin
|adresse_ip_web                |container_ip_web              |
82 1 Lionel Morin
83 3 Lionel Morin
*=> Ces variables peuvent être rajoutées en 2.4 pour une rétro-compatibilité*
84 1 Lionel Morin
85 1 Lionel Morin
h2. Modification des scripts shell
86 2 Lionel Morin
87 2 Lionel Morin
h3. CreoleGet
88 2 Lionel Morin
89 2 Lionel Morin
<pre>
90 2 Lionel Morin
.ParseDico
91 2 Lionel Morin
echo $mavariable
92 2 Lionel Morin
</pre>
93 2 Lionel Morin
est remplacé par :
94 2 Lionel Morin
<pre>
95 2 Lionel Morin
echo $(CreoleGet mavariable)
96 2 Lionel Morin
</pre>
97 2 Lionel Morin
98 2 Lionel Morin
ATTENTION : à ce jour, pour accéder à une variable esclave, il faut connaître la variable maître :
99 2 Lionel Morin
<pre>
100 1 Lionel Morin
echo $(CreoleGet lamaster.lesclave)
101 1 Lionel Morin
</pre>
102 2 Lionel Morin
103 12 Lionel Morin
*=> Il est possible de tester la présence de ParseDico avant de le lancer et ainsi faire en sorte d'avoir des scripts communs en 2.3 et en 2.4*
104 3 Lionel Morin
105 10 Lionel Morin
Code à confirmer :
106 7 Lionel Morin
<pre>
107 10 Lionel Morin
if type -p ParseDico &> /dev/null; then
108 11 Lionel Morin
    .ParseDico
109 11 Lionel Morin
else
110 11 Lionel Morin
    # initialisation des variables utilisées
111 11 Lionel Morin
    adresse_ip_br0=$(CreoleGet adresse_ip_br0)
112 1 Lionel Morin
fi
113 11 Lionel Morin
114 11 Lionel Morin
echo $adresse_ip_br0
115 7 Lionel Morin
</pre>
116 7 Lionel Morin
117 2 Lionel Morin
h3. CreoleRun
118 2 Lionel Morin
119 2 Lionel Morin
<pre>
120 2 Lionel Morin
./usr/share/eole/FonctionsEoleNg
121 2 Lionel Morin
RunCmd "ma -commande" conteneur
122 2 Lionel Morin
</pre>
123 2 Lionel Morin
est remplacé par :
124 1 Lionel Morin
<pre>
125 1 Lionel Morin
CreoleRun "ma -commande" conteneur
126 2 Lionel Morin
</pre>
127 3 Lionel Morin
128 3 Lionel Morin
*=> Il est possible d'émuler la commande RunCmd en 2.4*
129 2 Lionel Morin
130 2 Lionel Morin
h2. Problèmes spécifiques
131 2 Lionel Morin
132 2 Lionel Morin
h3. Problème de connexion aux bases MySQL #5633
133 2 Lionel Morin
134 2 Lionel Morin
Pour y remédier temporairement, on peut mettre "localhost" à la place de "127.0.0.1" (penser à la fois aux fichiers sql et aux fichiers de config php).