Gitlab

Accès distant aux conteneurs

Le workflow met à disposition du développeur des accès spécifiques aux conteneurs en utilisant une connexion SSH, afin de surveiller les services de l’application conteneurisée après son déploiement sur les environnements de préprod ou de production.

⚠️ C’est la clé publique qui sert à pousser le code dans les dépôts de Gitlab qui est utilisée pour l’accès aux conteneurs. Elle doit être uploadée dans votre profil Gitlab (User settings -> SSH Keys).

Surveiller le statut des services

Cette commande récapitule l’état des status des conteneurs utilisés par l’application, vus par compose sur le serveur de production:

ssh <myapp>@<my-host>.com ps

Cette commande affiche une sortie du type:

         Name                 Command        State    Ports  
-------------------------------------------------------------
testdemo_app_1           python -m app.web   Up      9000/tcp

Accéder aux conteneurs

Se connecter au conteneur de l’application

Exemple pour accéder en bash au conteneur du service “app”:

ssh -t <myapp>@<my-host>.com exec -ti [conteneur] bash

Lancer une commande sur un des services

Exemple pour lister les fichiers dans le conteneur:

ssh -t <myapp>@<my-host>.com exec -ti [conteneur] bash -c "ls -l"

Logs des conteneurs

Surveiller les logs des services de l’application

Cette commande affiche la sortie standard STDOUT de tous les services définis dans le Docker compose du projet:

ssh <myapp>@<my-host>.com logs

Pour afficher la sortie d’un service en particulier, ajouter son nom dans la commande:

ssh <myapp>@<my-host>.com logs [conteneur]
Top