serveurs:installation:docker

Installer Docker et Docker Compose

  • 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 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

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
  • 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
  • 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
  • É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) :
  • Si vous utiliser le container 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 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é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
  • 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 mettre à jour le fichier systemd s'il n'a pas encore été surchargé.

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 :
  • 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-<region>-sinp:/home/admin/docker/ --dry-run 

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=<futur-nom-de-la-stack> \
          --label com.docker.compose.version=<version-de-docker-compose> \
          --label com.docker.compose.volume=<nom-du-volume> \
          --name <futur-nom-de-la-stack>_<nom-du-volume>
      • 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 <ancien-nom-de-la-stack>_<nom-du-volume>:/from:ro \
          -v <futur-nom-de-la-stack>_<nom-du-volume>:/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

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 <bkp-srv-ssh-port>' -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.
  • Accéder aux logs du service Docker : journalctl -x -u docker.service
  • Lancer une image : docker run <image>
  • Lister toutes les images : docker image ls -a
  • Supprimer une image : docker image rm <image id>
  • Lister tous les containers : docker container ls --all
  • Supprimer un container : docker container rm <hash>
  • Construire une image à partir d'un fichier Dockerfile présent dans le dossier courant : docker build -t <nom>:<tag> .
  • Se connecter à un container : docker exec -it <container name> /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
  • 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 <service-name>
  • 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
  • serveurs/installation/docker.txt
  • Dernière modification : 2024/12/19 19:30
  • de jpmilcent