Comment installer Docker Compose sur Debian 9

introduction

Docker est un excellent outil pour automatiser le déploiement d’applications Linux à l’intérieur de conteneurs logiciels, mais pour tirer pleinement parti de son potentiel, chaque composant d’une application doit s’exécuter dans son propre conteneur. Orchestrer tous les conteneurs pour qu’ils démarrent, communiquent et s’arrêtent ensemble peut rapidement devenir fastidieux pour les applications complexes comportant de nombreux composants.

La communauté Docker a mis au point une solution populaire appelée Fig, qui vous permettait d’utiliser un seul fichier YAML pour orchestrer tous vos conteneurs et configurations Docker. Cela devint si populaire que l’équipe Docker décida de créer Docker Compose à partir de la source Fig, qui est maintenant déconseillée. Docker Compose permet aux utilisateurs d’orchestrer plus facilement les processus des conteneurs Docker, notamment le démarrage, l’arrêt et la configuration des liaisons et des volumes intra-conteneur.

Dans ce didacticiel, nous allons vous montrer comment installer la dernière version de Docker Compose pour vous aider à gérer les applications multi-conteneurs sur un serveur Debian 9.

Conditions préalables

Pour suivre cet article, vous aurez besoin de:

Étape 1 - Installation de Docker Compose

Bien que nous puissions installer Docker Compose à partir des référentiels Debian officiels, il existe plusieurs versions mineures derrière la dernière version. Nous allons donc l’installer à partir du référentiel GitHub de Docker. La commande ci-dessous est légèrement différente de celle que vous trouverez sur la page Releases. En utilisant l’indicateur + -o + pour spécifier le fichier de sortie en premier plutôt que de rediriger la sortie, cette syntaxe évite de rencontrer une erreur d’autorisation refusée provoquée lors de l’utilisation de + sudo +.

Nous allons vérifier la current release et, si nécessaire, le mettre à jour dans la commande ci-dessous:

sudo curl -L https://github.com/docker/compose/releases/download//docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose

Ensuite, nous allons définir les autorisations:

sudo chmod +x /usr/local/bin/docker-compose

Ensuite, nous vérifierons que l’installation a réussi en vérifiant la version:

docker-compose --version

Ceci imprimera la version que nous avons installée:

Outputdocker-compose version , build f46880fe

Maintenant que Docker Compose est installé, nous sommes prêts à exécuter un exemple «Hello World».

Étape 2 - Exécution d’un conteneur avec Docker Compose

Le registre public de Docker, Docker Hub, inclut une image Hello World à des fins de démonstration et de test. Il illustre la configuration minimale requise pour exécuter un conteneur à l’aide de Docker Compose: un fichier YAML qui appelle une seule image. Nous allons créer cette configuration minimale pour exécuter notre conteneur + hello-world +.

Tout d’abord, nous allons créer un répertoire pour le fichier YAML et y aller:

mkdir hello-world
cd hello-world

Ensuite, nous allons créer le fichier YAML:

nano docker-compose.yml

Placez le contenu suivant dans le fichier, enregistrez le fichier et quittez l’éditeur de texte:

docker-compose.yml

my-test:
image: hello-world

La première ligne du fichier YAML est utilisée dans le nom du conteneur. La deuxième ligne spécifie quelle image utiliser pour créer le conteneur. Lorsque nous exécutons la commande + docker-compos up +, elle recherche une image locale portant le nom que nous avons spécifié, + hello-world +. Avec cela en place, nous allons enregistrer et quitter le fichier.

Nous pouvons examiner manuellement les images sur notre système avec la commande + docker images:

docker images

Lorsqu’il n’y a aucune image locale, seuls les en-têtes de colonne affichent:

OutputREPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

Maintenant, tout en restant dans le répertoire + ~ / hello-world +, nous allons exécuter la commande suivante:

docker-compose up

La première fois que nous lançons la commande, s’il n’existe pas d’image locale nommée + hello-world, Docker Compose la extraira du référentiel public de Docker Hub:

OutputPulling my-test (hello-world:)...
latest: Pulling from library/hello-world
9db2ca6ccae0: Pull complete
Digest: sha256:4b8ff392a12ed9ea17784bd3c9a8b1fa3299cac44aca35a85c90c5e3c7afacdc
Status: Downloaded newer image for hello-world:latest
. . .

Après avoir extrait l’image, + docker-compose + crée un conteneur, attache et exécute le programme https://github.com/docker-library/hello-world/blob/85fd7ab65e079b08019032479a3f306964a28f4d/hello-world/Dockerfile {hello], qui confirme à son tour que l’installation semble fonctionner:

Output. . .
Creating helloworld_my-test_1...
Attaching to helloworld_my-test_1
my-test_1 |
my-test_1 | Hello from Docker.
my-test_1 | This message shows that your installation appears to be working correctly.
my-test_1 |
. . .

Ensuite, il affiche une explication de ce qu’il a fait:

Output To generate this message, Docker took the following steps:
my-test_1  |  1. The Docker client contacted the Docker daemon.
my-test_1  |  2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
my-test_1  |     (amd64)
my-test_1  |  3. The Docker daemon created a new container from that image which runs the
my-test_1  |     executable that produces the output you are currently reading.
my-test_1  |  4. The Docker daemon streamed that output to the Docker client, which sent it
my-test_1  |     to your terminal.

Les conteneurs Docker ne s’exécutent que tant que la commande est active. Par conséquent, une fois que + hello + a été exécuté, le conteneur s’est arrêté. Par conséquent, lorsque nous examinons les processus actifs, les en-têtes de colonne apparaissent, mais le conteneur + hello-world + ne sera pas répertorié car il ne s’exécute pas:

docker ps
OutputCONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS               NAMES

Nous pouvons voir les informations sur le conteneur, dont nous aurons besoin à la prochaine étape, en utilisant l’indicateur + -a +. Cela montre tous les conteneurs, pas seulement les actifs:

docker ps -a
OutputCONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS               NAMES
06069fd5ca23        hello-world         "/hello"            35 minutes ago      Exited (0) 35 minutes ago                       hello-world_my-test_1

Ceci affiche les informations dont nous aurons besoin pour supprimer le conteneur lorsque nous en aurons terminé.

Étape 3 - Suppression de l’image (facultatif)

Pour éviter d’utiliser trop d’espace disque, nous allons supprimer l’image locale. Pour ce faire, nous devrons supprimer tous les conteneurs qui référencent l’image à l’aide de la commande + docker rm +, suivie du + CONTAINER ID + ou du + NAME +. Ci-dessous, nous utilisons le + CONTAINER ID + de la commande + docker ps -a + que nous venons d’exécuter. Assurez-vous de remplacer l’ID de votre conteneur:

docker rm

Une fois que tous les conteneurs qui référencent l’image ont été supprimés, nous pouvons supprimer l’image:

docker rmi hello-world

Conclusion

Nous avons maintenant installé Docker Compose, testé notre installation en exécutant un exemple Hello World et supprimé l’image de test et le conteneur.

Bien que l’exemple de Hello World ait confirmé notre installation, la configuration simple ne montre pas l’un des principaux avantages de Docker Compose: être en mesure de faire monter et descendre simultanément un groupe de conteneurs Docker. Pour voir la puissance de Docker Compose en action, vous pouvez consulter cet exemple pratique, https://www.digitalocean.com/community/tutorials/how-to-configure-a-continuous-integration-testing-environment- with-docker-and-docker-compose-on-ubuntu-16-04 [Comment configurer un environnement de test d’intégration continue avec Docker et Docker Compose sur Ubuntu 16.04].