Comment installer et utiliser Docker sur Ubuntu 20.04 | DigitalOcean
Docker est une application qui simplifie le processus de gestion des processus d'application dans les conteneurs. Les conteneurs vous permettent d'exécuter vos applications dans des processus isolés des ressources. Ils sont similaires aux machines virtuelles, mais les conteneurs sont plus portables, plus respectueux des ressources et plus dépendants du système d'exploitation hôte.
Pour une introduction détaillée aux différents composants d'un conteneur Docker, consultez l'Écosystème Docker : Une introduction aux composants communs.
Dans ce tutoriel, vous allez installer et utiliser Docker Community Edition (CE) sur Ubuntu 20.04. Vous allez installer Docker lui-même, travailler avec des conteneurs et des images, et pousser une image vers un référentiel Docker.
Conditions préalables
Pour suivre ce tutoriel, vous aurez besoin des éléments suivants :
Un serveur Ubuntu 20.04 configuré en suivant le guide de configuration initiale de serveur Ubuntu 20.04, comprenant un utilisateur non root avec privilèges sudo et un pare-feu.
Un compte sur Docker Hub si vous souhaitez créer vos propres images et les pousser vers Docker Hub, comme indiqué dans les Étapes 7 et 8.
Étape 1 — Installation de Docker
Le package d'installation Docker disponible dans le référentiel officiel Ubuntu peut ne pas être la dernière version. Pour être sûr de disposer de la dernière version, nous allons installer Docker à partir du référentiel officiel Docker. Pour ce faire, nous allons ajouter une nouvelle source de paquets, ajouter la clé GPG de Docker pour nous assurer que les téléchargements sont valables, puis nous installerons le paquet.
Tout d'abord, mettez à jour votre liste de packages existante :
Ensuite, installez quelques paquets pré-requis qui permettent à apt
d'utiliser les paquets sur HTTPS :
Ensuite, ajoutez la clé GPG du dépôt officiel de Docker à votre système :
Ajoutez le référentiel Docker aux sources APT :
Ensuite, mettez à jour la base de données des paquets avec les paquets Docker à partir du référentiel qui vient d'être ajouté :
Assurez-vous que vous êtes sur le point d'installer à partir du dépôt Docker et non du dépôt Ubuntu par défaut :
Vous verrez un résultat comme celui-ci, bien que le numéro de version du Docker puisse être différent :
Output of apt-cache policy docker-ce
Notez que le docker-ce
n'est pas installé, mais que le candidat à l'installation provient du dépôt Docker pour Ubuntu 20.04 (focal
).
Enfin, installez Docker :
Le Docker devrait maintenant être installé, le démon démarré, et le processus autorisé à démarrer au boot. Vérifiez qu'il tourne :
La sortie devrait être similaire à ce qui suit, montrant que le service est actif et en cours d'exécution :
L'installation de Docker vous donne maintenant non seulement le service Docker (démon) mais aussi l'utilitaire en ligne de commande docker
, ou le client Docker. Nous allons voir comment utiliser la commande docker
plus loin dans ce tutoriel.
Étape 2 — Exécution de la commande Docker sans sudo (facultatif)
Par défaut, la commande docker
ne peut être exécutée que par l'utilisateur root ou par un utilisateur du groupe docker, qui est automatiquement créé lors du processus d'installation de Docker. Si vous essayez d'exécuter la commande docker
sans la faire précéder de sudo
ou sans être dans le groupe docker, vous obtiendrez un résultat comme celui-ci :
Si vous voulez éviter de taper sudo
chaque fois que vous exécutez la commande docker
, ajoutez votre nom d'utilisateur au groupe docker
:
Pour appliquer la nouvelle appartenance au groupe, déconnectez-vous du serveur et reconnectez-vous, ou tapez ce qui suit :
Vous serez invité à saisir le mot de passe utilisateur pour continuer.
Vérifiez que votre utilisateur est maintenant ajouté au groupe docker en tapant :
Si vous devez ajouter un utilisateur au groupe docker
pour lequel vous n'êtes pas connecté, déclarez ce nom d'utilisateur explicitement :
La suite de cet article suppose que vous exécutez la commande docker
en tant qu'utilisateur dans le groupe docker. Si vous choisissez de ne pas le faire, veuillez faire précéder les commandes de sudo
.
Examinons maintenant la commande docker
.
Étape 3 — Utilisation de la commande Docker
L'utilisation de docker
consiste à lui faire passer une chaîne d'options et de commandes suivie d'arguments. La syntaxe prend cette forme :
Pour voir toutes les sous-commandes disponibles, tapez :
À partir du docker 19, la liste complète des sous-commandes disponibles est incluse :
Pour voir les options disponibles pour une commande spécifique, tapez :
Pour voir les informations sur Docker à l'échelle du système, utilisez :
Examinons certaines de ces commandes. Nous allons commencer par travailler avec des images.
Étape 4 — Travailler avec des images Docker
Les conteneurs Docker sont construits à partir d'images Docker. Par défaut, Docker tire ces images de Docker Hub, un registre Docker géré par Docker, l'entreprise à l'origine du projet Docker. Tout le monde peut héberger ses images Docker sur Docker Hub, de sorte que la plupart des applications et des distributions Linux dont vous aurez besoin y auront des images hébergées.
Pour vérifier si vous pouvez accéder et télécharger des images de Docker Hub, tapez :
La sortie indiquera que Docker fonctionne correctement :
Au départ, Docker n'a pas pu trouver l'image hello-world
localement, il a donc téléchargé l'image depuis Docker Hub, qui est le référentiel par défaut. Une fois l'image téléchargée, Docker a créé un conteneur à partir de l'image et l'application dans le conteneur s'est exécutée, affichant le message.
Vous pouvez rechercher des images disponibles sur Docker Hub en utilisant la commande docker
avec la sous-commande search
. Par exemple, pour rechercher l'image Ubuntu, tapez :
Le script va parcourir Docker Hub et retourner une liste de toutes les images dont le nom correspond à la chaîne de recherche. Dans ce cas, la sortie sera similaire à celle-ci :
Dans la colonne OFFICIAL, OK indique une image construite et soutenue par l'entreprise à l'origine du projet. Une fois que vous avez identifié l'image que vous souhaitez utiliser, vous pouvez la télécharger sur votre ordinateur à l'aide de la sous-commande pull
.
Exécutez la commande suivante pour télécharger l'image officielle d’ubuntu
sur votre ordinateur
Vous verrez la sortie suivante :
Une fois qu'une image a été téléchargée, vous pouvez alors lancer un conteneur en utilisant l'image téléchargée avec la sous-commande run
. Comme vous l'avez vu avec l'exemple hello-world
, si une image n'a pas été téléchargée lorsque docker
est exécuté avec la sous-commande run
, le client Docker téléchargera d'abord l'image, puis lancera un conteneur en l'utilisant.
Pour voir les images qui ont été téléchargées sur votre ordinateur, tapez :
La sortie ressemblera à ce qui suit :
Comme vous le verrez plus loin dans ce tutoriel, les images que vous utilisez pour gérer les conteneurs peuvent être modifiées et utilisées pour générer de nouvelles images, qui peuvent ensuite être téléchargées (poussées est le terme technique) vers Docker Hub ou d'autres registres Docker.
Voyons comment exécuter des conteneurs plus en détail.
Étape 5 — Exécution d'un conteneur Docker
Le conteneur hello-world
que vous avez exécuté à l'étape précédente est un exemple de conteneur qui fonctionne et qui quitte après avoir émis un message de test. Les conteneurs peuvent être beaucoup plus utiles que cela, et ils peuvent être interactifs. Après tout, ils sont similaires aux machines virtuelles, mais ils sont plus économes en ressources.
À titre d'exemple, exécutons un conteneur en utilisant la dernière image d'Ubuntu. La combinaison des commutateurs -i et -t vous donne un accès interactif au shell dans le conteneur :
Votre invite de commande devrait changer pour refléter le fait que vous travaillez maintenant à l'intérieur du conteneur et devrait prendre cette forme :
Notez l'identifiant du conteneur dans l'invite de commande. Dans cet exemple, il s'agit de d9b100f2f636
. Vous aurez besoin de cet ID de conteneur plus tard pour identifier le conteneur lorsque vous voudrez le supprimer.
Vous pouvez maintenant exécuter n'importe quelle commande à l'intérieur du conteneur. Mettons par exemple à jour la base de données des paquets à l'intérieur du conteneur. Vous ne devez pas préfixer une commande avec sudo
, car vous opérez à l'intérieur du conteneur en tant qu'utilisateur root :
Ensuite, installez n'importe quelle application dans le conteneur. Installons Node.js :
Ceci installe Node.js dans le conteneur à partir du dépôt officiel d'Ubuntu. Une fois l'installation terminée, vérifiez que Node.js est installé :
Vous verrez le numéro de version affiché dans votre terminal :
Les modifications que vous apportez à l'intérieur du conteneur ne s'appliquent qu'à ce conteneur.
Pour quitter le conteneur, tapez exit
à l'invite.
Voyons maintenant comment gérer les conteneurs sur notre système.
Étape 6 — Gestion des conteneurs Docker
Après avoir utilisé Docker pendant un certain temps, vous aurez de nombreux conteneurs actifs (en cours d'exécution) et inactifs sur votre ordinateur. Pour voir les actifs, utilisez :
Vous verrez une sortie similaire à celle-ci :
Dans ce tutoriel, vous avez lancé deux conteneurs ; un à partir de l'image hello-world
et un autre à partir de l'image ubuntu
. Les deux conteneurs ne sont plus actifs, mais ils existent toujours sur votre système.
Pour voir tous les conteneurs, actifs et inactifs, exécutez docker ps
avec le commutateur -a
:
Vous verrez une sortie semblable à celle-ci :
Pour voir le dernier conteneur que vous avez créé, passez-le au commutateur -l
:
Pour démarrer un conteneur arrêté, utilisez docker start
, suivi de l'ID du conteneur ou de son nom. Démarrons le conteneur basé sur Ubuntu avec l'ID de 1c08a7a0d0e4
:
Le conteneur démarrera, et vous pouvez utiliser docker ps
pour voir son statut
Pour arrêter un conteneur en cours d'exécution, utilisez docker stop
, suivi de l'ID ou du nom du conteneur. Cette fois, nous utiliserons le nom que Docker a attribué au conteneur, qui est quizzical_mcnulty
:
Une fois que vous avez décidé que vous n'avez plus besoin d'un conteneur, retirez-le avec la commande docker rm
, en utilisant à nouveau l'ID ou le nom du conteneur. Utilisez la commande docker ps -a
pour trouver l'ID ou le nom du conteneur associé à l'image hello-world
et supprimez-le.
Vous pouvez démarrer un nouveau conteneur et lui donner un nom en utilisant le commutateur --name
. Vous pouvez également utiliser le commutateur --rm
pour créer un conteneur qui se supprime de lui-même lorsqu'il est arrêté. Voir la commande docker run help
pour plus d'informations sur ces options et d'autres.
Les conteneurs peuvent être transformés en images que vous pouvez utiliser pour construire de nouveaux conteneurs. Voyons comment cela fonctionne.
Étape 7 — Transformation d'un conteneur en une image Docker
Lorsque vous démarrez une image Docker, vous pouvez créer, modifier et supprimer des fichiers comme vous le pouvez avec une machine virtuelle. Les modifications que vous apportez ne s'appliqueront qu'à ce conteneur. Vous pouvez le démarrer et l'arrêter, mais une fois que vous l'aurez détruit avec la commande docker rm
, les modifications seront perdues pour de bon.
Cette section vous montre comment enregistrer l'état d'un conteneur en tant que nouvelle image Docker.
Après avoir installé Node.js dans le conteneur Ubuntu, vous avez maintenant un conteneur qui s'exécute à partir d'une image, mais le conteneur est différent de l'image que vous avez utilisée pour le créer. Mais vous pourriez vouloir réutiliser ce conteneur Node.js comme base pour de nouvelles images plus tard.
Ensuite, effectuez les modifications dans une nouvelle instance d'image Docker à l'aide de la commande suivante.
Le commutateur -m est destiné au message de validation qui vous aide, ainsi que les autres, à connaître les modifications que vous avez apportées, tandis que -a est utilisé pour spécifier l'auteur. Le container_id
est celui que vous avez noté plus tôt dans le tutoriel lorsque vous avez lancé la session interactive de Docker. À moins de créer des référentiels supplémentaires sur Docker Hub, le référentiel
est généralement votre nom d'utilisateur Docker Hub.
Par exemple, pour l'utilisateur sammy, avec l'ID de conteneur d9b100f2f636
, la commande serait :
Lorsque vous validez une image, la nouvelle image est enregistrée localement sur votre ordinateur. Plus loin dans ce tutoriel, vous apprendrez comment pousser une image vers un registre Docker comme Docker Hub pour que d'autres puissent y accéder.
L'énumération des images Docker affichera à nouveau la nouvelle image, ainsi que l'ancienne image dont elle est issue :
Vous verrez une sortie de ce type :
Dans cet exemple, ubuntu-nodejs
est la nouvelle image, qui a été dérivée de l'image ubuntu
existante à partit de Docker Hub. La différence de taille reflète les modifications apportées. Et dans cet exemple, le changement est que NodeJS a été installé. Donc la prochaine fois que vous aurez besoin d'exécuter un conteneur en utilisant Ubuntu avec NodeJS pré-installé, vous pourrez simplement utiliser la nouvelle image.
Vous pouvez également construire des images à partir d'un Dockerfile
, qui vous permet d'automatiser l'installation de logiciels dans une nouvelle image. Cependant, cela n'entre pas dans le cadre de ce tutoriel.
Partageons maintenant la nouvelle image avec d'autres personnes afin qu'elles puissent créer des conteneurs à partir de celle-ci.
Étape 8 — Pousser des images Docker dans un référentiel Docker
L'étape logique suivante après la création d'une nouvelle image à partir d'une image existante est de la partager avec quelques amis choisis, le monde entier sur Docker Hub, ou tout autre registre Docker auquel vous avez accès. Pour pousser une image vers Docker Hub ou tout autre registre Docker, vous devez y avoir un compte.
Cette section vous montre comment pousser une image Docker vers Docker Hub. Pour apprendre comment créer votre propre registre Docker privé, consultez Comment configurer un registre Docker privé sur Ubuntu 14.04.
Pour pousser votre image, connectez-vous d'abord à Docker Hub.
Vous serez invité à vous s'authentifier à l'aide de votre mot de passe Docker Hub. Si vous avez spécifié le bon mot de passe, l'authentification devrait réussir.
Remarque : Si votre nom d'utilisateur du registre Docker est différent du nom d'utilisateur local que vous avez utilisé pour créer l'image, vous devrez tagger votre image avec votre nom d'utilisateur du registre. Pour l'exemple donné à la dernière étape, vous devriez taper :
Ensuite, vous pouvez pousser votre propre image à l'aide de :
Pour pousser l'image ubuntu-nodejs
vers le référentiel sammy, la commande serait :
Le processus peut prendre un certain temps pour s'achever car il télécharge les images, mais une fois terminé, la sortie ressemblera à ceci :
Après avoir poussé une image vers un registre, elle doit être répertoriée sur le tableau de bord de votre compte, comme le montre l'image ci-dessous.
Si une tentative de push entraîne une erreur de ce type, c'est que vous ne vous êtes probablement pas connecté :
Connectez-vous avec le docker login
et répétez la tentative de poussée. Vérifiez ensuite qu'elle existe sur votre page de dépôt Docker Hub.
Vous pouvez maintenant utiliser docker pull sammy/ubuntu-nodejs
pour tirer l'image vers une nouvelle machine et l'utiliser pour lancer un nouveau conteneur.
Conclusion
Dans ce tutoriel, vous avez installé Docker, travaillé avec des images et des conteneurs, et poussé une image modifiée sur Docker Hub. Maintenant que vous connaissez les bases, explorez les autres tutoriels de Docker dans la communauté DigitalOcean.
Source :
Dernière mise à jour