Déploiement ============= Le dossier `deployment/roles` contient des *roles*, c'est-à-dire des élément d'installation exécutés par ansible sur le serveur. Le fichier `playbook.yml` définit l'ordre dans lequel ansible lance les roles. - `common` installe le paquet debian. - `nginx` installe le reverse proxy. - `certbot` ajoute le certificat https. - `archive` : - lance la commande git archive qui crée un tar.gz à partir du dossier de la webapp ; - met cette archive dans `deployment/roles/archive/files` ; - copie l'archive dans le dossier `opt` du serveur ; - extraie l'archive dans le serveur : le code de la webapp est donc copiée dans le serveur. - `pip` installe les librairies Python nécessaires sur le serveur. - `run` lance l'application Flask. - `mongodb` installe mongodb sur le serveur. L'activation de l'ensemble des roles est automatisée avec le script `run_playbook.sh`. Procédure d'installation ------------------------ 1. Dans `princevault`, *activer le venv* : - faire le decrypt : `./vault decrypt` ; - ajouter la clef ssh : `ssh-keygen -f "/.ssh/known_hosts" -R ""`, `ssh-copy-id -i /.ssh/id_ed25519.pub debian@`. 2. Dans `webapp` : - copier/coller le param.yaml de `princevault` et le renommer. - pour livrer une version de la webapp il faut créer un tag : `git checkout main`, `git merge develop`, `git tag -a -m ""`. 3. Dans `deployment`, *activer le venv* : - copier/coller le main.yml de `princevault/deployment` dans `deployment/group_vars/all`, le renommer et vérifier que le bon tag est renseigner dans `application_release_tag`. - lancer le playbook (`./install.sh`), qui lance les rôles : - Rôle common. `deployment/roles/common/tasks/main.yml` : installation et mise à jour du système et des outils. (cron renouvelle le certificat https) - Rôle ngnx. `deployment/roles/nginx/tasks/main.yml` : compléter les fichiers de `/etc/nginx/sites-enabled/`. Pour ajouter une autre appli, faire une variable `domain2`. - Rôle certbot. - Rôle archive. - Rôle pip. - Rôle mongodb. 4. Dans `datascience`, *activer le venv* : - copier/coller le param.yml de `princevault/datascience` dans `datascience/actes-princiers/conf/local` - installer les librairies : `pip install -r ./actes-princiers/src/requirements.txt` - récupéer les dernières données : `./data_registry_update.sh` - effacer le contenu de 02_intermediate`./clean_intermediate_data.sh` - dans `datascience/actes-princiers` : `kedro run --tags="etl_transform"` - (scp -r datascience/ @:~/) - `kedro run --tags="populate_database"` 5. Dans `deployment`, *activer le venv* : - Lancement de l'application (`launch_playbook.yml`) avec `./launch_application.sh` 7. Publier l'application en cas de mise à jour : `deployment/publish.sh`