====== Installer Docker et Docker Compose ====== ===== Installer le dépôt Docker ===== * Méthode installation pour Debian : https://docs.docker.com/engine/install/debian/ * Installer le dépôt Docker : * Mettre à jour les dépôts : ''apt update'' * Installer les paquets suivant : ''apt install ca-certificates curl gnupg'' * Ajouter la clé du dépôt Docker : sudo install -m 0755 -d /etc/apt/keyrings curl -fsSL https://download.docker.com/linux/debian/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg sudo chmod a+r /etc/apt/keyrings/docker.gpg * Ajouter le fichier apt contenant le dépôt Docker : echo \ "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian \ "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | \ sudo tee /etc/apt/sources.list.d/docker.list > /dev/null ===== Installer Docker ===== * Installer les paquets nécessaire : ''apt install apt-transport-https gnupg2 software-properties-common'' * Installer Docker : ''apt install docker-ce docker-ce-cli containerd.io'' * Activer le service Docker au démarrage : ''systemctl enable docker'' * Ajouter l'utilisateur //admin// au groupe //docker// : ''usermod -aG docker admin'' * Se connecter sur une console avec l'utilisateur //admin// et tester Docker : ''docker run hello-world'' * Si le message d'erreur ''docker: Got permission denied while trying to connect to the Docker daemon socket'' apparait : * Essayer de sourcer à nouveau le fichier ''.bashrc'' : ''source ~/.bashrc'' * Essayer de redémarrer la machine pour activer la prise en compte de Docker * Tester à nouveau le bon fonctionnement de Docker : ''docker run hello-world'' ==== Limiter la mémoire et le CPU des containers Docker ==== Afin de pouvoir limiter la consommation de mémoire et de CPU des containers Docker, il est nécessaire de vérifier que le noyau Linux est compilé avec les bonnes options : Si le noyau est correctement compiler, vous pouvez passer à l'étape suivante : * Vérifier si la configuration de l'hôte est nécessaire : '' docker info '' * Si la commande précédente afficher le message suivant il est nécessaire de suivre les étapes suivantes : **WARNING: No swap limit support** * Éditer le fichier de configuration de Grub et y ajouter/compléter le contenu suivant : '' vi /etc/default/grub '' GRUB_CMDLINE_LINUX="cdgroup_enable=memory swapaccount=1" * Valider la prise en compte de la modification précédente avec la commande : '' update-grub '' * Redémarrer la machine : ''reboot'' * Vérifier que le message **WARNING: No swap limit support** a disparu : '' docker info '' ==== Déplacer le dossier contenant les données de Docker ==== * Par défaut, les données de Docker sont stockées dans un unique dossier : ''/var/lib/docker/'' * Passer en root : ''sudo -i'' * Commencer par arrêter le service : ''systemctl stop docker'' * Vérifier l'arrêt : ''systemctl status docker'' * Vérifier qu'il n'y ait plus de processus Docker : ''ps faux | grep -i docker'' * Créer un fichier ''/etc/docker/daemon.json'' dans lequel vous indiquerez le nouveau dossier : ''vi /etc/docker/daemon.json'' * Contenu du fichier ''/etc/docker/daemon.json'' : { "data-root": "/data/docker" } * Créer le dossier de destination des données de Docker : ''sudo mkdir /data/docker'' * Copier les données dans le nouveau dossier : ''rsync -avxPS /var/lib/docker/ /data/docker'' * Vérifier que les tailles des 2 dossiers correspondent : ''du -hs /var/lib/docker/; du -hs /data/docker'' * Renommer l'ancien dossier : ''mv /var/lib/docker /var/lib/docker.old'' * Redémarrer le service Docker : ''systemctl start docker'' * Vérifier le statut : ''systemctl status docker'' * Vérifier le nouvel emplacement : * ''docker info | grep 'Docker Root Dir' '' * Accéder aux interfaces web des outils utilisant Docker, si Portainer est installé vérifier le paramètre //Root directory// de l'hôte. * Vérifier que les containers ont démarrés et fonctionnent comme prévu : ''docker ps'' * Si tout est ok, supprimer l'ancien dossier : ''rm -rf /var/lib/docker.old'' ===== Installer Docker Compose ===== * Dans les versions récentes de Docker, Compose est directement intégré à la commande ''docker''. Si la commande suivante afficher la version de Compose, inutile de suivre les étapes suivantes : ''docker compose version'' * Installer //docker-compose// v2 : ''apt install docker-compose-plugin'' * Vérifier la version installée : ''%%docker --help |grep compose%%'' * NOTES : supprimer l'ancienne version v1 télécharger manuellement : ''rm -f /usr/local/bin/docker-compose ; rm -f /etc/bash_completion.d/docker-compose'' ===== Activer IPv6 pour Docker ===== * Éditer le fichier ///etc/docker/daemon.json// : ''vi /etc/docker/daemon.json'' * Ajouter les paramètres suivant : { "ipv6": true, "fixed-cidr-v6": "c01d:c01a:cafe::/64", "experimental": true, "ip6tables": true } * Redémarrer Docker : ''systemctl restart docker'' * Vérifier la prise en compte d'IPv6 dans le réseau par défaut : ''docker network inspect bridge|grep EnableIPv6'' * Si vous avez déjà créer votre réseau local Docker (Ex. //nginx-proxy//) : * éteindre tous les containers via Portainer par exemple. * supprimer votre réseau : ''docker network rm nginx-proxy'' * [[serveurs:installation:docker#creation_d_un_reseau_local_docker|créer à nouveau le réseau externe (nginx-proxy) avec l'activation d'IPv6]] * Redémarrer toutes les stacks avec : ''docker compose down; docker compose up -d'' * Si vous utiliser le container [[https://hub.docker.com/r/nginxproxy/nginx-proxy|nginxproxy/nginx-proxy]] activer l'écoute sur les IPv6 en plus d'IPv4: ports: - "0.0.0.0:80:80" - "0.0.0.0:443:443" - "[::]:80:80" - "[::]:443:443" * Vous pouvez vérifier la bonne écoute sur les ports 80 et 443 de l'IPv6 locale avec : ''ss -6ltpn'' * Si vous utiliser [[https://hub.docker.com/r/nginxproxy/docker-gen|nginxproxy/docker-gen]], activer le support d'IPv6 dans le fichier //docker-compose.yml// : environment: ENABLE_IPV6: true * Tester la connectivité IPv6 vers votre site web avec : https://ready.chair6.net/ ===== Création d'un réseau local Docker ===== * Créer un réseau local de type bridge "utilisateur" compatible IPv4 et IPv6 avec : '' docker network create --driver=bridge --ipv6 --subnet=172.18.5.0/24 --ip-range=172.18.5.0/24 --subnet a1f:ea75:ca75::/48 --gateway=172.18.5.1 nginx-proxy '' * Ainsi, depuis un container associé à ce réseau, il est possible d'adresser l'hôte avec l'IP de la gateway, soit : 172.18.5.1 * De limiter les accès sur un outil de l'hôte aux IP des container de ce réseau qui seront créé parmi (--ip-range) : 172.18.5.0/24 ===== Activer l'API Docker sur l'instance ===== Voir la [[serveurs:installation:db-srv:docker-api|documentation d'activation de l'API Docker]]. ===== Mise à jour de Docker et Docker Compose ===== * La mise à jour se fait via le système de paquet de Debian à l'aide d'Apt. * Suite à une mise à jour de Docker sur l'instance "db", il est nécessaire de [[serveurs:installation:db-srv:docker-api|mettre à jour le fichier systemd]] s'il n'a pas encore été surchargé. ===== Copier les fichiers docker-compose.yml depuis le dépôt Github sinp--srv ===== Les fichiers //docker-compose.yml// des différents outils de suivi sont hébergés dans un dépôt Github. Il est nécessaire de copier ces fichiers sur les différentes instances afin de pouvoir les installer. * Les dépôts : * SINP PACA : https://github.com/cbn-alpin/sinp-paca-srv * SINP AURA : https://github.com/cbn-alpin/sinp-aura-srv * Ces depôts contiennent les dossiers de base suivant : * //bkp-srv// : les fichiers pour l'instance "bkp-srv" * //db-srv// : les fichiers pour l'instance "db-srv" * //shared// : les fichiers communs aux différentes instances. * //web-srv// : les fichiers pour l'instance "web-srv" * Chacun de ces dossiers de base contient ensuite une arborescence de dossiers comparable à celle du serveur correspondant. * Les fichiers //docker-compose.yml// sont hébergés par le dossier de l'utilisateur //admin//. * Pour chaque serveur, synchroniser ces fichiers avec le serveur correspondant en utilisant ''rsync'' : * Se placer à la racine du dépôt * Lancer la commande ''rsync'' suivante, ici pour //web-srv// et le dossier ///web-srv/home/admin/docker// avec l'option ''%%--dry-run%%'' (à supprimer quand tout est ok) : rsync -av ./web-srv/home/admin/docker/ admin@web--sinp:/home/admin/docker/ --dry-run ===== Renommer une stack générer via docker-compose ===== Lorsqu'on lancer ''docker-compose up'', Docker-Compose se charge de créer les volumes nommés. Lors de leur création, il utilise le nom du dossier dans lequel se trouve le fichier ''docker-compose.yml''. Ainsi, si l'on change ultérieurement ce nom de dossier, Docker-Compose recréer de nouveaux volumes nommés au prochaine lancement. Il est donc nécessaire de suivre la procédure suivante pour renommer le dossier d'une stack créé par Docker-Compose : * Se placer dans le dossier de la stack et arrêter les services : ''docker-compose down'' * Renommer le dossier de la stack. Ex. : ''mv monitor.silene.eu monitor'' * Lister tous les volumes utilisés par la stack via Portainer via le menu "Volumes" puis utiliser le filtre en tapant le premier mot composant le nom du dossier. Ex. : pour le dossier "monitor.silene.eu", taper "monitor". La stack correspondante est nommée "monitorsileneeu". * Pour chaque volume listé, il est nécessaire de : * créer un nouveau volume avec le nouveau nom : docker volume create \ --label com.docker.compose.project= \ --label com.docker.compose.version= \ --label com.docker.compose.volume= \ --name _ * Ex. : docker volume create \ --label com.docker.compose.project=monitor \ --label com.docker.compose.version=1.24.1 \ --label com.docker.compose.volume=influxdb-storage \ --name monitor_influxdb-storage * S'assurer via Portainer que le nouveau volume a été créé correctement (nom et labels). * Copier les données de l'ancien volume vers le nouveau : docker run --rm -it \ -v _:/from:ro \ -v _:/to \ alpine ash -c "cd /from ; cp -av . /to" * Ex. : docker run --rm -it \ -v monitorsileneeu_influxdb-storage:/from:ro \ -v monitor_influxdb-storage:/to \ alpine ash -c "cd /from ; cp -av . /to" * Se placer dans le nouveau dossier de la stack et lancer les services : ''docker-compose up -d'' * Vérifier que tout fonctionne correctement ===== Déplacer les données (volumes nommés) de Docker d'un serveur à un autre ===== Il est possible de déplacer les volumes nommés d'un serveur à un autre : * Mettre à jour Docker sur les 2 instances pour avoir la même version installée. * Arrêter les services utilisant les volumes sur les serveur d'origine : ''docker compose down'' * Si possible arrêter également Docker : ''systemctl stop docker'' * Rechercher les dossiers des volumes nommées concernés dans : ''/var/lib/docker/volumes/'' * Une fois repéré, copier chaque dossier sur le serveur de destination. Il est neccessaire de passer par l'utilisateur //admin// car il n'y a pas d'accès direct à root sur le serveur de destination. Ex. avec le volume nommé //matomo-storage// dans la stack //analytics// : ''rsync -e 'ssh -p ' -avxP analytics_matomo-storage/ admin@bkp-paca-sinp:~/dwl/analytics_matomo-storage/'' * Sur le serveur de destination, déplacer le dossier dans l'emplacement (non standard) des données de docker (sur ''/data/docker/'') : ''mv analytics_matomo-storage /data/docker/volumes/'' * Modifier le propriétaire qui a été défini à //admin// par le propriétaire initial, généralement //root// (vérifier sur le serveur d'origine) : ''chown --from=admin root -R /data/docker/volumes/analytics_matomo-storage '' * Modifier le DNS pour faire pointer le nom de domaine sur le nouveau serveur. * Vous pouvez maintenant ré-installer les fichiers Docker Compose sur le nouveau serveur. * Modifier les éventuels fichiers de configuration ou ''.env'' pour adapter la configuration au nouveau serveur. * Relancer la stack : ''docker compose up -d'' * Vérifier que tout fonctionne à nouveau. ===== Commandes utiles ===== * Accéder aux logs du service Docker : '' journalctl -x -u docker.service '' ==== Docker ==== * Lancer une image : ''docker run '' * Lister toutes les images : ''docker image ls -a'' * Supprimer une image : ''docker image rm '' * Lister tous les containers : ''docker container ls --all'' * Supprimer un container : ''docker container rm '' * Construire une image à partir d'un fichier //Dockerfile// présent dans le dossier courant : ''docker build -t : .'' * Se connecter à un container : ''docker exec -it /bin/bash'' * Depuis un container (si ''ip'' est installé - paquet //iproute2//), afficher l'IP de l'hôte : ''ip route|awk '/default/ { print $3 }''' * Informations sur la place occupée par Docker : * Résumé de la place occupée : docker system df * Infos détaillées dont la place occupée par chaque volume : docker system df --verbose * Nettoyage : * **ATTENTION:** **s'assurer au préalable que tous les containers utiles sont bien actif sur l'hôte !** * Nettoyer tout (images, containers et réseaux) inactifs : docker system prune * Nettoyer tout (images, containers et réseaux) et les volumes contenant des données (!!) inactifs : docker system prune --volumes ==== Docker Compose ==== * **Source** : https://opensharing.fr/docker-compose-commandes-utiles * ** build **: * Construire ou reconstruire les images des services dont le Dockerfile a été modifié : '' docker-compose build [SERVICE...] '' * Construire ou reconstruire les images avec les dernières versions des images de base : '' docker-compose build --pull [SERVICE...] '' * Construire ou reconstruire les images sans utiliser le cache : '' docker-compose build --no-cache '' * ** config **: * Vérifier la configuration et la syntaxe du fichier Docker Compose : '' docker-compose config '' * Lister les services définis dans le fichier Docker Compose : '' docker-compose config --services '' * Lister les volumes définis dans le fichier Docker Compose : '' docker-compose config --volumes '' * ** down ** : * Arrêter les services, supprimer les containers et les réseaux de l’application : '' docker-compose down '' * Arrêter les services, supprimer les containers, les réseaux et les volumes : '' docker-compose down --volumes '' * Arrêter les services, supprimer les containers, les réseaux, les volumes et les images construites et téléchargées (**ATTENTION** : la suppression des volumes entraine la perte de toutes les données associées aux containers) : '' docker-compose down --volumes --rmi all '' * ** up **: * Reconstruire et redémarrer un service seulement : '' docker-compose up -d --no-deps --build '' * ** Divers ** : * Exécuter une commande à l'intérieur d'un container : '' docker-compose exec [options] [-e KEY=VAL...] SERVICE COMMAND [ARGS...] '' * Lister les images utilisées (téléchargées et construites) par les containers de services : '' docker-compose images [SERVICE...] '' * Afficher la sortie produite par les services spécifiés : '' docker-compose logs [options] [SERVICE...] '' Ex. '' docker-compose logs -f --tail=3 ''