Project

General

Profile

FrRedmineUpgrade » History » Version 13

Pierre Labrie, 2012-09-21 21:36

1 1 Fabrice Phung
h1. Mise à jour
2
3 5 yannick quenec'hdu
{{>toc}}
4 2 yannick quenec'hdu
5 5 yannick quenec'hdu
h2. Étape 1 - Vérifier les pré-requis
6 1 Fabrice Phung
7 7 yannick quenec'hdu
La première étape pour la mise à jour de Redmine est de vérifier que vous remplissez les [[FrRedmineInstall#Exigence|exigences]] de la version que vous vous apprêtez à installer.
8 1 Fabrice Phung
9 5 yannick quenec'hdu
h2. Étape 2 - Sauvegarde
10 1 Fabrice Phung
11 8 yannick quenec'hdu
Il est recommandé de [[FrRedmineInstall#Sauvegarde|sauvegarder]] vos données et vos fichiers. La plupart des mises à jour sont sans danger, mais il est toujours prudent de réaliser une sauvegarde dans le cas contraire.
12 1 Fabrice Phung
13 5 yannick quenec'hdu
h2. Étape 3 - réaliser la mise à jour
14
15
Le processus de mise à jour est dépendant de la manière que vous avez téléchargé Redmine. Vous avez besoin de réaliser seulement une des options suivantes :
16
17
h3. Option 1 - Mettre à jour depuis une version téléchargée (fichier tar.gz ou zip)
18
19
1. Décompresser la nouvelle archive du programme dans un nouveau répertoire.
20
21 9 Pierre Labrie
2. Copiez vos paramètres de base @config/database.yml@ dans le nouveau répertoire de configuration @config@. Si vous utilisez Redmine >=1.4 avec MySql et Ruby 1.9, changez l'adapteur pour _mysql2_.
22 5 yannick quenec'hdu
23 9 Pierre Labrie
3a. Copiez vos paramètres de configuration @config/configuration.yml@ dans le nouveau répertoire de configuration @config@.
24 5 yannick quenec'hdu
25 9 Pierre Labrie
3b. Si vous migrez depuis une version plus vielle qe 1.2.0, copiez vos configurations de courriel de votre @config/email.yml@ dans le nouveau @config/configuration.yml@ dont l'exemple peut être copié du fichier @configuration.yml.example@.
26 1 Fabrice Phung
27 9 Pierre Labrie
4. Copiez le contenu de @RAILS_ROOT/files@ dans le répertoire de votre nouvelle installation
28 1 Fabrice Phung
29 9 Pierre Labrie
5. Copiez le répertoire contenant vos plugin personnalisé de votre répertoire @vendor/plugins@ dans le répertoire @plugins@ de votre nouvelle installation ( si vous migrez d'une version antérieure à 2.0.0 vers une version >= 2.0.0). Assurez-vous de ne copier que les plugins différents de l'installation originale de Remine de votre précdente installation.
30
31 1 Fabrice Phung
6. Exécturer les commandes suivantes depuis le répertoire Redmine de votre nouvelle installation
32 5 yannick quenec'hdu
33 9 Pierre Labrie
<pre>
34
rake config/initializers/session_store.rb
35
</pre>
36 5 yannick quenec'hdu
37 9 Pierre Labrie
Si vous utilisez une nouvelle version de Redmine, les fichiers indiqués au dessous n'existent pas encore. Pour ces versions, exécuter :<pre>
38
rake generate_session_store
39
</pre>
40 5 yannick quenec'hdu
41
Cette commande va générer un fichier (@config/initializers/session_store.rb@) avec un secret aléatoire utilisé pour sécuriser les données de session.
42
43
7. Vérifier pour tous les thèmes que vous possédez que vous pouvez les installer dans le répertoire "public/themes". Vous pouvez les copier, mais il est préférable de vérifier qu'il y a une version mise à jour.
44
45 6 yannick quenec'hdu
TRÈS IMPORTANT : Ne pas écraser le fichier config/settings.yml avec l'ancienne version
46 5 yannick quenec'hdu
47 1 Fabrice Phung
h3. Option 2 - Mettre à jour depuis un checkout SVN  [[FrRedmineRepositories|Dépot]]
48
49 5 yannick quenec'hdu
1. Allez dans le répertoire racine de Redmine et exécutez la commande suivante:
50
51
  <pre>
52 1 Fabrice Phung
svn update
53
</pre>
54 5 yannick quenec'hdu
55 1 Fabrice Phung
56 10 Pierre Labrie
2. Si vous faites une mise à jour depuis une ancienne version vers la 0.8.7 ou supérieur (depuis une version du trunk jusqu'à r2493 ou plus), vous devez générer un secret pour le stockage des cookies. Voyez la note à la fin pour la génération de l'entrepot de session.
57 7 yannick quenec'hdu
58 5 yannick quenec'hdu
h2. Étape 4 - Mise à jour de la base de données
59
60 1 Fabrice Phung
Cette étape va modifier le contenu de la base de données. Allez dans le répertoire de votre nouvelle installation de Redmine et effectuez la commande suivante :
61 5 yannick quenec'hdu
62 1 Fabrice Phung
<pre>
63
rake db:migrate RAILS_ENV=production 
64 5 yannick quenec'hdu
</pre>
65 1 Fabrice Phung
66 11 Pierre Labrie
Si vous avez installé des plugin, vous devrez effectuer une migration de la base de données. Effectuer la commande suivante :
67 1 Fabrice Phung
68 5 yannick quenec'hdu
<pre>
69 11 Pierre Labrie
rake redmine:plugins:migrate RAILS_ENV=production 
70 1 Fabrice Phung
</pre>
71
72 11 Pierre Labrie
Ou pour Windows:
73
74 1 Fabrice Phung
<pre>
75 11 Pierre Labrie
set RAILS_ENV=production
76
rake db:migrate  
77
</pre>
78
79
<pre>
80
set RAILS_ENV=production
81
rake redmine:plugins:migrate  
82 5 yannick quenec'hdu
</pre>
83 1 Fabrice Phung
84 5 yannick quenec'hdu
h2. Étape 5 - Nettoyage 
85 1 Fabrice Phung
86 5 yannick quenec'hdu
1. Vous devez nettoyer le cache et les sessions existantes, pour ce faire, exécuter les commandes suivantes :
87
88
<pre>
89
rake tmp:cache:clear
90 1 Fabrice Phung
rake tmp:sessions:clear
91 5 yannick quenec'hdu
</pre>
92 1 Fabrice Phung
93 5 yannick quenec'hdu
2. Redémarrez l'application (ex : mongrel, thin, passenger) 
94 1 Fabrice Phung
95
3. Finalement, lancez votre navigateur et allez dans_"Administration -> Rôles & permissions"_ pour vérifier et/ou paramétrer les permissions sur les nouvelles fonctionnalités, s'il y en a.
96 12 Pierre Labrie
97
h2. Problémes fréquents
98
99
h3. Erreurs avec la gestion des dépôts
100
101
102
h3. Generation d'un nouveau secret @secret_token.rb@
103
104
Avant 2.0.0, un fichier @session_store.rb@ devait être généré dans le répertoire @config@ pour permettre les sessions basées sur les fichiers témoins (_cookies_).
105
106
À partir de la version 2.0.0 le fichier @session_store.rb@ ne devrait plus exister. À la place la commande suivante va générer le fichier @secret_token.rb@.
107
108
109
<pre>
110
rake generate_secret_token
111
</pre>
112
113
> Note: le dépot du code de Redmine ne contient pas pas le fichier config/initializers/secret_token.rb file, c'est le code précédent qui le crée.
114
115
h3. Erreurs pour @member_roles@
116
117 13 Pierre Labrie
Si vous avez raté une mise à jour/migration dans le passé, vous pouvez avoir une table @member_roles@ et/ou @group_users@ déjà existante et la migration de BD mentionnée précédemment échouera. Simplement renommez les tables en ouvrant une console de commande sur MySql et en exécutant les commandes suivantes:
118 12 Pierre Labrie
119
<pre>
120
mysql> rename table member_roles to member_roles_saved
121
mysql> rename table groups_users to groups_users_saved
122
</pre>
123
124
h3. Erreurr au sujet de "undefined method `add_frozen_gem_path'"
125
126
Si vous avez cette erreur, vérifiez si le répertoire vendor/rails existe et retirez ou renommez le. Il pourrait avoir une vieille version de Ruby on Rails. 
127
128
h3. Références
129
130
Ces références peuvent vous aider à la mise à niveau de Redmine:
131
132
* "mod_fcgid for Apache2":http://httpd.apache.org/mod_fcgid/  pour aider au fonctionnement de Rails sur Apache 2
133
* "Running Redmine on Apache":http://www.redmine.org/wiki/redmine/HowTo_configure_Apache_to_run_Redmine
134
* "Notes about our 0.8.6 to 0.9.3 upgrade issues and how to resolve them":http://www.cybersprocket.com/2010/project-management/upgrading-redmine-from-8-6-to-9-3/ --cybersprocket (2010-04-25)
135
* "Notes about our 0.9.6 to 1.0(RC) upgrade process":http://www.cybersprocket.com/2010/tips-tricks/upgrading-redmine-from-0-9-6-to-1-0-0/ --cybersprocket (2010-08-14)