DocScoDoc/docs/MigrationScoDoc7a9.md

190 lines
6.7 KiB
Markdown
Raw Normal View History

2021-08-26 14:23:51 +02:00
# Migration des données ScoDoc 7 vers ScoDoc 9
2024-05-30 15:26:44 +02:00
On peut installer à partir de zéro (cas 1), ou sur une machine ayant déjà un ScoDoc 7
et migrer les données (cas 2).
2021-08-26 14:23:51 +02:00
## Cas 1: Migration d'une installation ScoDoc 7 sur un nouveau serveur
2021-09-24 20:31:25 +02:00
C'est la voie recommandée, notamment si vous avez un parc de machines
virtuelles, car elle minimise la durée de coupure et permet de tester avant de
2021-08-26 14:23:51 +02:00
basculer d'une version à l'autre.
2021-09-24 20:31:25 +02:00
Dans ce cas, la migration va se faire en suivant les étapes, détaillées plus loin:
2021-08-26 14:23:51 +02:00
1. installer le nouveau serveur Linux Debian 11 et ScoDoc 9;
2024-05-30 15:26:44 +02:00
2021-08-26 14:23:51 +02:00
2. sauvegarder les données de ScoDoc7 depuis le serveur de production **et l'arrêter**;
3. charger les données ScoDoc 7 sur le nouveau serveur;
4. importer ces données dans ScoDoc 9.
2021-09-24 20:31:25 +02:00
Si vous venez d'installer ScoDoc 9, passez directement à l'**étape 3**.
2021-08-26 14:23:51 +02:00
### Étape 1: Installer le nouveau serveur
2024-05-30 15:26:44 +02:00
Installer le nouveau serveur avec Debian 12 et ScoDoc 9.
2021-08-26 14:23:51 +02:00
2024-05-30 15:26:44 +02:00
Voir [GuideInstallDebian12](GuideInstallDebian12.md).
2021-08-26 14:23:51 +02:00
Vérifier que tout fonctionne avant d'aller plus loin.
### Étape 2: Sauvegarder les données du serveur ScoDoc 7
2021-09-14 12:31:16 +02:00
Ouvrir un terminal en tant que `root`sur l'ancien serveur ScoDoc 7.
2021-08-26 14:23:51 +02:00
cd /opt/scodoc/Products/ScoDoc/config
# Mise à jour indispensable pour avoir le script de migration
./upgrade.sh
# Arrêt du service en production
systemctl stop scodoc
# Export des données
./save_scodoc7_data.sh /tmp/sauvegarde-scodoc7
2024-05-30 15:26:44 +02:00
Attention à l'espace disque: au besoin, faire le ménage ou montez un disque supplémentaire.
2021-08-26 14:23:51 +02:00
Notez que cette migration ne fonctionne qu'à partir de la dernière version de
ScoDoc 7. Si vous avez une version plus ancienne, mettez-la d'abord à jour.
Le script indique le nom du fichier à transférer, qui sera dans
l'exemple ci-dessus `/tmp/sauvegarde-scodoc7.tgz`
Copier ce fichier sur le nouveau serveur (scp, ...).
### Étape 3: Charger les données ScoDoc 7
2021-09-24 20:31:25 +02:00
Récupérez l'archive transférée sur le nouveau serveur et ouvrez-la (vous êtes
toujours `root`):
2021-08-26 14:23:51 +02:00
cd /tmp
tar xfz sauvegarde-scodoc7.tgz
2021-09-06 12:35:49 +02:00
chown -R scodoc /tmp/sauvegarde-scodoc7
2021-08-26 14:23:51 +02:00
commande qui va créer `/tmp/sauvegarde-scodoc7`.
2021-09-24 20:31:25 +02:00
Chargement des bases SQL ScoDoc 7: en tant qu'utilisateur "`scodoc`":
2021-08-26 14:23:51 +02:00
2021-09-24 20:31:25 +02:00
su scodoc
2021-08-26 14:23:51 +02:00
/opt/scodoc/tools/restore_scodoc7_data.sh /tmp/sauvegarde-scodoc7
(adaptez l'argument si les données ont été copiées ailleurs)
Note: les messages d'erreur comme
pg_restore: warning: restoring tables WITH OIDS is not supported anymore
pg_restore: error: could not execute query: ERROR: schema "public" already exists
pg_restore: error: could not execute query: ERROR: must be owner of extension plpgsql
sont normaux et a priori anodins.
A ce stade, vous avez rechargé les bases ScoDoc 7 mais il faut encore
les convertir vers la nouvelle structure ScoDoc 9, et importer les photos,
archives et autres fichiers: c'est l'objet de l'étape suivante.
### Étape 4: Importer les données dans ScoDoc 9
Les formats des bases ayant changé l'opération est complexe et peut durer
2021-09-06 12:35:49 +02:00
plusieurs minutes (ou dizaines de minutes). Attention: **Il faut lancer le script en tant
que `root` **.
2021-08-26 14:23:51 +02:00
su # passer root d'une façon ou d'une autre
# lancer le script, avec le nom du répertoire:
/opt/scodoc/tools/migrate_from_scodoc7.sh /tmp/sauvegarde-scodoc7
## Cas 2: Migration "en place" sur la même machine
Si vous n'avez pas la possibilité de changer de serveur (par exemple, vous ne
travaillez pas dans des machines virtuelles, ou qu'il est compliqué de créer une
nouvelle VM). Vous pouvez partir de ScoDoc 7 / Debian 10, faire l'upgrade Debian
en place, puis migrer ScoDoc 9.
2021-09-06 12:35:49 +02:00
Avant tout, sauvegardez évidemment votre serveur complet, vérifiez que la
2021-09-24 20:31:25 +02:00
sauvegarde est bonne et que plusieurs exemplaires sont stockés en lieux sûrs,
2021-08-26 14:23:51 +02:00
comme d'habitude.
Toutes les étapes sont importantes, prenez votre temps, lisez bien cette page.
2021-09-24 20:31:25 +02:00
Si vous venez d'installer ScoDoc 9, passez directement à l'**étape 4**.
2021-08-26 14:23:51 +02:00
### 1. Préparation et arrêt de ScoDoc 7
2021-09-24 20:31:25 +02:00
1. **S'assurer que l'installation ScoDoc 7 est à jour**
2021-08-26 14:23:51 +02:00
sudo su
cd /opt/scodoc/Products/ScoDoc/config
./upgrade.sh
Notez que cette migration ne fonctionne qu'à partir de la dernière version
de ScoDoc 7. Si vous avez une version plus ancienne, mettez-la d'abord à
jour.
2021-09-24 20:31:25 +02:00
2. **Arrêter le service ScoDoc 7**
2021-08-26 14:23:51 +02:00
systemctl stop scodoc
S'assurer qu'il est bien stoppé (`ps auxw`, ...), sans quoi la migration va échouer.
2021-09-24 20:31:25 +02:00
3. **Renommer le répertoire de ScoDoc 7**
2021-08-26 14:23:51 +02:00
sudo su
mv /opt/scodoc /opt/scodoc7
Les données seront migrées après installation la nouvelle version, voir
plus loin. ScoDoc 9 sera installé dans `/opt/scodoc`, il est donc très important
de renommer le répertoire en `scodoc7`.
### 2. Upgrade Debian
Suivre la procédure standard. La [doc
officielle](https://www.debian.org/releases/bullseye/mips64el/release-notes/ch-upgrading.fr.html)
2021-09-24 20:31:25 +02:00
est longue, mais en réalité c'est très simple et prends moins de 10 minutes,
sauf si vous avez configuré votre système de façon exotique.
2021-08-26 14:23:51 +02:00
Nombreux tutos disponibles, voir [par exemple
2024-05-30 15:26:44 +02:00
celui-ci](https://www.cyberciti.biz/faq/update-upgrade-debian-10-to-debian-11-bullseye/).
2021-08-26 14:23:51 +02:00
2021-09-06 12:35:49 +02:00
Attention, il faut désinstaller Apache (avant ou après upgrade Linux), car
ScoDoc 9 utilise un autre serveur web (nginx) qui serait en conflit:
# peut être utile pour récuperer vos certificats SSL ?
2024-05-30 15:26:44 +02:00
mv /etc/apache2 /etc/apache2.old
2021-09-06 12:35:49 +02:00
apt-get remove --purge apache2
2024-05-30 15:26:44 +02:00
2021-09-06 12:35:49 +02:00
2021-08-26 14:23:51 +02:00
### 3. Installer ScoDoc 9
2024-05-30 15:26:44 +02:00
2024-05-30 15:32:10 +02:00
Voir [la section 2 du guide d'installation](GuideInstallDebian12.md#2-installation-de-scodoc-sur-debian).
2021-08-26 14:23:51 +02:00
Vérifier que tout fonctionne avant d'aller plus loin.
### 4. Migrer vos données ScoDoc 7
2024-05-30 15:26:44 +02:00
Les données sont restées dans `/opt/scodoc7`.
2021-08-26 14:23:51 +02:00
Lancer le script suivant en tant que `root`:
2021-09-06 12:35:49 +02:00
/opt/scodoc/tools/migrate_from_scodoc7.sh -m
2021-08-26 14:23:51 +02:00
(l'option `-m` indique qu'il s'agit d'une migration "en place").
La migration prends du temps, et il n'est pas inutile de consulter les messages
affichés, dont la plupart se retrouvent aussi dans le fichier
/opt/scodoc/data/log/migration79.log
Prêtez attention aux éventuels changements de login des utilisateurs et
informez-les. ScoDoc 9 n'autorise pas de caractères spéciaux (apostrophes, ...)
ou accentués dans les logins.
### 5. Vérifier que tout fonctionne
2021-09-14 12:31:16 +02:00
Vos départements et utilisateurs devraient être accessibles.
L'utilisateur `admin` créé à l'installation de ScoDoc 9 doit avoir accès à tout.
2021-08-26 14:23:51 +02:00
Vérifiez que les semestres, étudiants, photos, archives et comptes utilisateurs
sont bien là.
2021-09-24 20:31:25 +02:00
Au besoin, réglez la fonction de calcul du **bonus sport&culture** via la page
"configuration" accessible depuis la page d'accueil en tant qu'admin uniquement.
2021-08-26 14:23:51 +02:00
Célébrez !