Skip to content
Pierre Mauduit edited this page Mar 4, 2016 · 12 revisions

GeoCat - procédure de déploiement

TL;DR

Pour un "nouvel arrivant", déployer geocat reviendrait en théorie à:

git clone [email protected]:camptocamp/geocat.git /var/www/vhosts/tc-geocat/private/geocat.ch.<user>

Editer geocat.ch.deploy/core.deploy.sh et changer le REPO_DIR pour pointer sur le répertoire précédemment créé (ligne 24).

Lancer le script nécessaire au déploiement sur l’environnement souhaité:

./deploy.to.localhost.sh

pour dev par exemple.

(Procédure non testée pour le moment en dehors de mon utilisateur)

Explications

Ceci est un exercice d’ingénierie inverse du travail laissé par Jesse pour le déploiement sur GeoCat. Tous ses bouts de code font d'ailleurs l'objet d'un dépot spécifique ici: https://github.com/camptocamp/geocat_deploy.

Avant son départ, Jesse avait rédigé des procédures de déploiement sous forme de Shell-script complexes et difficilement maintenables. Bien que loin d’être parfaite, cette procédure a permis de passer en production la version actuelle de Geocat.

A noter que ces scripts devaient addresser deux uses-cases:

Mise en production du code (webapp uniquement) Chargement initial d’une base de données (ancienne ou nouvelle version du schéma) + données (datadir geonetwork)

Suite à la mise en production, le second mode de fonctionnement a été abandonné (pour éviter toute perte évidente de données dû à un potentiel rechargement inopportun de la base).

Serveurs

  • ssh0a.prod.bgdi.ch
  • 10.220.4.102 (serveur de test)
  • 10.220.4.214 (serveur d’intégration)
  • 10.220.5.105 (production)

Les 3 derniers serveurs ne sont accessibles que via le premier (penser à bien forwarder son agent avec -A ou avoir une configuration SSH adéquate).

Scripts

Tous les scripts laissés par Jesse se trouvent sur le serveur de test dans le répertoire:

/var/www/vhosts/tc-geocat/private/geocat.ch.deploy

Si on s’attarde un répertoire plus haut dans l’arborescence:

pmauduit@ip-10-220-4-102 (vpc/geocat - test):/var/www/vhosts/tc-geocat/private$ ls -lh
[...]
lrwxrwxrwx  1 pmauduit geodata   18 Oct 13 18:20 geocat.ch -> geocat.ch.pmauduit
drwxr-sr-x  4     1112 geodata 4.0K Sep 30 08:53 geocat.ch.deploy
drwxr-sr-x 38 fgravin  geodata 4.0K Sep 25 18:52 geocat.ch.git
drwxr-sr-x 38 pmauduit geodata 4.0K Jan 19 17:48 geocat.ch.pmauduit
drwxr-sr-x 38     1112 geodata 4.0K Sep 29 14:38 geocat.jesse.checkout

Comme chaque utilisateur a son compte propre, pour éviter des problèmes de droits, il est nécessaire pour la personne souhaitant déployer GeoCat d’effectuer un git clone spécifique dans geocat.ch.<utilisateur> et de faire pointer le lien symbolique geocat.ch (TODO: a vérifier, peut-être inutile) sur ce répertoire avant déploiement.

Retour dans le répertoire précédent, nous retrouvons quelques scripts shell ainsi qu’un sous-répertoire hooks. Il y a un script par environnement, et un principal utilisé par les autres: core.deploy.sh.

$ ls -l
[...]
-rwxrwxr-x 1 1112 geodata 2811 Jan  6 16:18 core.deploy.sh
-rwxrwxr-x 1 1112 geodata   99 Feb 20  2015 deploy.to.all.sh
-rwxrwxr-x 1 1112 geodata  237 Oct  8  2014 deploy.to.integration.sh
-rwxrwxr-x 1 1112 geodata  234 Oct  8  2014 deploy.to.jenkins.sh
-rwxrwxr-x 1 1112 geodata  230 Sep 25 18:24 deploy.to.localhost.sh
-rwxrwxr-x 1 1112 geodata  333 Oct  8  2014 deploy.to.production.sh
-rwxrwxr-x 1 1112 geodata  536 Nov 18 15:56 deploy.to.shadow.sh
-rw-rw-r-- 1 1112 geodata  723 Feb 23 21:11 geocat.cfg
drwxrwsr-x 4 1112 geodata 4096 Oct 27 21:02 hooks

(Note: 1112 correspond sans doute à l’uid de l’utilisateur jeichar, détruit dorénavant)

core.deploy.sh contient donc toute la logique du processus de déploiement, deploy.to.all.sh, comme son nom ne l’indique pas, permet de déployer sur dev et int à la suite (mais pas sur la production).

deploy.to.shadow.sh correspond au déploiement sur l’environnement “shadow” ; cet environnement n’est plus utilisé mais correspondait à la “nouvelle production” avant la mise en production effective de novembre 2015. Depuis le passage en production, nous utilisons deploy.to.production.sh pour le déploiement sur l'environnement de production.

deploy.to.localhost.sh permet de déployer sur l’environnement de test.

A noter que les deploy.to.*.sh permettaient le passage d’un argument optionel “all”, qui, si activé avait pour effet de recharger un dump de la base de données (situé dans hooks/geocat/initialDump.sql.gz). Ce paramêtre n’a quasiment jamais été utilisé suite au passage en production.

A noter la présence du répertoire hooks/geocat/conf/ qui définit la configuration (ip) des serveurs en fonction de l’environnement considéré (un peu redondant avec ce qui est déjà défini dans le core.deploy.sh, mais cette redondance peut s'expliquer par le fait que tout est rsync lorsque le déploiement n'est pas local, et que le script de deploy a sans doute besoin d'avoir l'information une fois envoyé sur un serveur distant).

hooks/geocat/data contient le datadir geocat à déployer (mais n’est censé être utilisé que si le mode all du deploy est utilisé ? TODO A vérifier).

Faire de la rétro-ingénierie sur le reste du sous-répertoire hooks/geocat prendrait un temps considérable, on peut s’intéroger sur la présence d’un interpréteur scala dont la seule présence semble être justifiée par un script IsIndexing.scala, appelé dans le hooks/support-functions.sh, et peut-être appelé lors du core.deploy.sh, mais sans certitude.

Clone this wiki locally