3.05 Déployer avec docker compose le fichier docker compose.yml
Objectifs pédagogiques
- Comprendre le format de fichier YAML
- Savoir identifier les directives principales du fichier docker-compose.yml
Docker Compose
Nous avons pu constater que lancer plusieurs conteneurs liés avec leur mapping réseau et les volumes liés implique des commandes assez lourdes. Cela devient ingérable si l'on a beaucoup d'applications microservice avec des réseaux et des volumes spécifiques.
Pour faciliter tout cela et dans l'optique d'Infrastructure as Code, Docker introduit un outil nommé docker-compose qui permet de décrire de applications multiconteneurs grâce à des fichiers YAML.
Pour bien comprendre qu'il s'agit au départ uniquement de convertir des options de commande Docker en YAML, un site vous permet de convertir une commande docker run
en fichier Docker Compose : https://www.composerize.com/
Le code est sur https://github.com/docker/compose, docker-compose est un fat binary en go qui pèse seulement ~30 Mo.
Le "langage" de Docker Compose
Documentation
- la documentation du langage (DSL) des compose-files
man docker-compose
N'hésitez pas à passer du temps à explorer les options et commandes dedocker-compose
.
il est aussi possible d'utiliser des variables d'environnement dans Docker Compose : se référer au mode d'emploi pour les subtilités de fonctionnement
Syntaxe
Alignement ! (2 espaces !!)
ALIGNEMENT !! (comme en python)
ALIGNEMENT !!! (le défaut du YAML, pas de correcteur syntaxique automatique, c'est bête mais vous y perdrez forcément quelques heures !
des listes (tirets)
des paires clé: valeur
Un peu comme du JSON, avec cette grosse différence que le JSON se fiche de l'alignement et met des accolades et des points-virgules
les extensions Docker et YAML dans VSCode vous aident à repérer des erreurs
Les erreurs courantes quotes, et deux-points :
titre: Un exemple: on va avoir des soucis
titre: "Un exemple: on va avoir des soucis"
Exemples de fichier Docker Compose
Une belle source d'exemples +- officielle: https://github.com/docker/awesome-compose
Sans build : un wordpress sur le port 80
version: '3.3'
services:
wordpress:
depends_on:
- mysqlpourwordpress
environment:
- "WORDPRESS_DB_HOST=mysqlpourwordpress:3306"
- WORDPRESS_DB_PASSWORD=monwordpress
- WORDPRESS_DB_USER=wordpress
networks:
- wordpress
ports:
- "80:80"
image: wordpress
volumes:
- wordpress_config:/var/www/html/
mysqlpourwordpress:
image: "mysql:5.7"
environment:
- MYSQL_ROOT_PASSWORD=motdepasseroot
- MYSQL_DATABASE=wordpress
- MYSQL_USER=wordpress
- MYSQL_PASSWORD=monwordpress
networks:
- wordpress
volumes:
- wordpress_data:/var/lib/mysql/
networks:
wordpress:
volumes:
wordpress_config:
wordpress_data:
Avec build : un ruby on rails sur le port 80
Un deuxième exemple :
version: '3.3'
services:
postgres:
image: postgres:10
environment:
POSTGRES_USER: rails_user
POSTGRES_PASSWORD: rails_password
POSTGRES_DB: rails_db
networks:
- back_end
redis:
image: redis:3.2-alpine
networks:
- back_end
rails:
build: .
depends_on:
- postgres
- redis
environment:
DATABASE_URL: "postgres://rails_user:rails_password@postgres:5432/rails_db"
REDIS_HOST: "redis:6379"
networks:
- front_end
- back_end
volumes:
- .:/app
nginx:
image: nginx:latest
networks:
- front_end
ports:
- 80:80
volumes:
- ./nginx.conf:/etc/nginx/conf.d/default.conf:ro
networks:
front_end:
back_end:
Utiliser Docker compose
Les commandes
Docker compose était un programme indépendant de Docker proposant un executable docker-compose
à part. Depuis quelques temps cet outil a été intégré comme un plugin de la CLI Docker, le Compose Plugin.
On écrit maintenant les commandes compose comme une sous commande de docker: docker compose up
Les commandes suivantes sont couramment utilisées lorsque vous travaillez avec Compose. La plupart se passent d'explications et ont des équivalents Docker directs, mais il vaut la peine d'en être conscient·e :
build
reconstruit toutes les images créées à partir de Dockerfiles. La commande up ne construira pas une image à moins qu'elle n'existe pas, donc utilisez cette commande à chaque fois que vous avez besoin de mettre à jour une image (quand vous avez édité un Dockerfile). On peut aussi fairedocker compose up --build
up
démarre tous les conteneurs définis dans le fichier compose et agrège la sortie des logs. Normalement, vous voudrez utiliser l'argument-d
pour exécuter Compose en arrière-plan.run
fait tourner un conteneur pour exécuter une commande unique. Cela aura aussi pour effet de faire tourner tout conteneur décrit dansdepends_on
, à moins que l'argument--no-deps
ne soit donné.stop
arrête les conteneurs sans les enlever.ps
fournit des informations sur le statut des conteneurs gérés par Compose.logs
affiche les logs. De façon générale la sortie des logs est colorée et agrégée pour les conteneurs gérés par Compose.down
détruit tous les conteneurs définis dans le fichier Compose, ainsi que les réseaux. Pour détruire les volumes et ainsi réinitialisé toutes les données on peut ajouter l'option-v
.rm
supprime les conteneurs à l'arrêt. On peut aussi utiliser l'argument-v
pour supprimer tous les volumes gérés par Docker.
Le workflow de développement Docker Compose
Compose est un outil d'infrastructure as code declaratif : à chaque fois qu'on lance docker compose up
seul les conteneurs ayant changé dans le code sont mis à jour en fonction de la description dans le docker-compose.yml
workflow de base:
- lire/ecrire le code du
docker-compose.yml
- facultatif:
docker compose build
si besoin pour reconstruire les images docker ayant changé - facultatif: exécuter les taches de préparation avec
docker compose up <db>
pour monter seulement certains conetenrus etdocker compose run <conteneur> <commande>
pour préparer par exemple une base de donnée. voir section usage non synchrone plus bas. docker compose up -d
va créer tous les conteneursdocker compose ps
etdocker compose logs
pour vérifier que tout se passe bien dans les conteneursdocker compose down
tout arrêter quand on a fini de développer avec-v
en plus si il faut nettoyer les données.
Usage non synchrone de docker-compose
On peut également exécuter des tâches une par une dans les conteneurs du docker-compose sans démarrer tous les conteneurs simultanéement. Comme par exemple pour une migration de base de donnée. Exemple : https://docs.funkwhale.audio/installation/docker.html#start-funkwhale-service
On peut également exécuter des tâches une par une dans les conteneurs du docker-compose sans démarrer tous les conteneurs simultanéement. Comme par exemple pour une migration de base de donnée.
Exemple : https://docs.funkwhale.audio/administrator/installation/docker.html#set-up-funkwhale
Visualisation des applications microservice complexes
Certaines applications microservice peuvent avoir potentiellement des dizaines de petits conteneurs spécialisés.
Le service devient alors difficile à lire dans le compose file.
Il est possible de visualiser l'architecture d'un fichier Docker Compose en utilisant docker-compose-viz:
- https://github.com/pmsipilot/docker-compose-viz
sudo apt-get install graphviz
docker run --rm -it --name dcv -v $(pwd):/input pmsipilot/docker-compose-viz render -m image docker-compose.yml
Cet outil peut être utilisé dans un cadre d'intégration continue pour produire automatiquement la documentation pour une image en fonction du code.