Autres
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 :

É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 :
1
sudo apt update
Copied!
Ensuite, installez quelques paquets pré-requis qui permettent à apt d'utiliser les paquets sur HTTPS :
1
sudo apt install apt-transport-https ca-certificates curl software-properties-common
Copied!
Ensuite, ajoutez la clé GPG du dépÎt officiel de Docker à votre systÚme :
1
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
Copied!
Ajoutez le référentiel Docker aux sources APT :
1
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu focal stable"
Copied!
Ensuite, mettez Ă  jour la base de donnĂ©es des paquets avec les paquets Docker Ă  partir du rĂ©fĂ©rentiel qui vient d'ĂȘtre ajoutĂ© :
1
sudo apt update
Copied!
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 :
1
apt-cache policy docker-ce
Copied!
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
1
docker-ce:
2
Installed: (none)
3
Candidate: 5:19.03.9~3-0~ubuntu-focal
4
Version table:
5
5:19.03.9~3-0~ubuntu-focal 500
6
500 https://download.docker.com/linux/ubuntu focal/stable amd64 Packages
Copied!
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 :
1
sudo apt install docker-ce
Copied!
Le Docker devrait maintenant ĂȘtre installĂ©, le dĂ©mon dĂ©marrĂ©, et le processus autorisĂ© Ă  dĂ©marrer au boot. VĂ©rifiez qu'il tourne :
1
sudo systemctl status docker
Copied!
La sortie devrait ĂȘtre similaire Ă  ce qui suit, montrant que le service est actif et en cours d'exĂ©cution :
1
Output● docker.service - Docker Application Container Engine
2
Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
3
Active: active (running) since Tue 2020-05-19 17:00:41 UTC; 17s ago
4
TriggeredBy: ● docker.socket
5
Docs: https://docs.docker.com
6
Main PID: 24321 (dockerd)
7
Tasks: 8
8
Memory: 46.4M
9
CGroup: /system.slice/docker.service
10
└─24321 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
Copied!
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 :
1
Outputdocker: Cannot connect to the Docker daemon. Is the docker daemon running on this host?.
2
See 'docker run --help'.
Copied!
Si vous voulez éviter de taper sudo chaque fois que vous exécutez la commande docker, ajoutez votre nom d'utilisateur au groupe docker :
1
sudo usermod -aG docker ${USER}
Copied!
Pour appliquer la nouvelle appartenance au groupe, déconnectez-vous du serveur et reconnectez-vous, ou tapez ce qui suit :
1
su - ${USER}
Copied!
Vous serez invité à saisir le mot de passe utilisateur pour continuer.
Vérifiez que votre utilisateur est maintenant ajouté au groupe docker en tapant :
1
id -nG
Copied!
1
Outputsammy sudo docker
Copied!
Si vous devez ajouter un utilisateur au groupe docker pour lequel vous n'ĂȘtes pas connectĂ©, dĂ©clarez ce nom d'utilisateur explicitement :
1
sudo usermod -aG docker username
Copied!
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 :
1
docker [option] [command] [arguments]
Copied!
Pour voir toutes les sous-commandes disponibles, tapez :
1
docker
Copied!
À partir du docker 19, la liste complùte des sous-commandes disponibles est incluse :
1
Output attach Attach local standard input, output, and error streams to a running container
2
build Build an image from a Dockerfile
3
commit Create a new image from a container's changes
4
cp Copy files/folders between a container and the local filesystem
5
create Create a new container
6
diff Inspect changes to files or directories on a container's filesystem
7
events Get real time events from the server
8
exec Run a command in a running container
9
export Export a container's filesystem as a tar archive
10
history Show the history of an image
11
images List images
12
import Import the contents from a tarball to create a filesystem image
13
info Display system-wide information
14
inspect Return low-level information on Docker objects
15
kill Kill one or more running containers
16
load Load an image from a tar archive or STDIN
17
login Log in to a Docker registry
18
logout Log out from a Docker registry
19
logs Fetch the logs of a container
20
pause Pause all processes within one or more containers
21
port List port mappings or a specific mapping for the container
22
ps List containers
23
pull Pull an image or a repository from a registry
24
push Push an image or a repository to a registry
25
rename Rename a container
26
restart Restart one or more containers
27
rm Remove one or more containers
28
rmi Remove one or more images
29
run Run a command in a new container
30
save Save one or more images to a tar archive (streamed to STDOUT by default)
31
search Search the Docker Hub for images
32
start Start one or more stopped containers
33
stats Display a live stream of container(s) resource usage statistics
34
stop Stop one or more running containers
35
tag Create a tag TARGET_IMAGE that refers to SOURCE_IMAGE
36
top Display the running processes of a container
37
unpause Unpause all processes within one or more containers
38
update Update configuration of one or more containers
39
version Show the Docker version information
40
wait Block until one or more containers stop, then print their exit codes
41
​
Copied!
Pour voir les options disponibles pour une commande spécifique, tapez :
1
docker docker-subcommand --help
Copied!
Pour voir les informations sur Docker Ă  l'Ă©chelle du systĂšme, utilisez :
1
docker info
Copied!
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 :
1
docker run hello-world
Copied!
La sortie indiquera que Docker fonctionne correctement :
1
OutputUnable to find image 'hello-world:latest' locally
2
latest: Pulling from library/hello-world
3
0e03bdcc26d7: Pull complete
4
Digest: sha256:6a65f928fb91fcfbc963f7aa6d57c8eeb426ad9a20c7ee045538ef34847f44f1
5
Status: Downloaded newer image for hello-world:latest
6
​
7
Hello from Docker!
8
This message shows that your installation appears to be working correctly.
9
​
10
...
11
​
Copied!
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 :
1
docker search ubuntu
Copied!
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 :
1
OutputNAME DESCRIPTION STARS OFFICIAL AUTOMATED
2
ubuntu Ubuntu is a Debian-based Linux operating sys
 10908 [OK]
3
dorowu/ubuntu-desktop-lxde-vnc Docker image to provide HTML5 VNC interface 
 428 [OK]
4
rastasheep/ubuntu-sshd Dockerized SSH service, built on top of offi
 244 [OK]
5
consol/ubuntu-xfce-vnc Ubuntu container with "headless" VNC session
 218 [OK]
6
ubuntu-upstart Upstart is an event-based replacement for th
 108 [OK]
7
ansible/ubuntu14.04-ansible Ubuntu 14.04 LTS with
8
...
9
​
Copied!
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
1
docker pull ubuntu
Copied!
Vous verrez la sortie suivante :
1
OutputUsing default tag: latest
2
latest: Pulling from library/ubuntu
3
d51af753c3d3: Pull complete
4
fc878cd0a91c: Pull complete
5
6154df8ff988: Pull complete
6
fee5db0ff82f: Pull complete
7
Digest: sha256:747d2dbbaaee995098c9792d99bd333c6783ce56150d1b11e333bbceed5c54d7
8
Status: Downloaded newer image for ubuntu:latest
9
docker.io/library/ubuntu:latest
Copied!
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 :
1
docker images
Copied!
La sortie ressemblera Ă  ce qui suit :
1
OutputREPOSITORY TAG IMAGE ID CREATED SIZE
2
ubuntu latest 1d622ef86b13 3 weeks ago 73.9MB
3
hello-world latest bf756fb1ae65 4 months ago 13.3kB
Copied!
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 :
1
docker run -it ubuntu
Copied!
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 :
1
apt update
Copied!
Ensuite, installez n'importe quelle application dans le conteneur. Installons Node.js :
1
apt install nodejs
Copied!
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é :
1
node -v
Copied!
Vous verrez le numéro de version affiché dans votre terminal :
1
Outputv10.19.0
Copied!
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 :
1
docker ps
Copied!
Vous verrez une sortie similaire Ă  celle-ci :
1
OutputCONTAINER ID IMAGE COMMAND CREATED
2
​
Copied!
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 :
1
docker ps -a
Copied!
Vous verrez une sortie semblable Ă  celle-ci :
1
1c08a7a0d0e4 ubuntu "/bin/bash" 2 minutes ago Exited (0) 8 seconds ago quizzical_mcnulty
2
a707221a5f6c hello-world "/hello" 6 minutes ago Exited (0) 6 minutes ago youthful_curie
3
​
Copied!
Pour voir le dernier conteneur que vous avez créé, passez-le au commutateur -l :
1
docker ps -l
Copied!
1
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
2
1c08a7a0d0e4 ubuntu "/bin/bash" 2 minutes ago Exited (0) 40 seconds ago quizzical_mcnulty
3
​
Copied!
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 :
1
docker start 1c08a7a0d0e4
Copied!
Le conteneur démarrera, et vous pouvez utiliser docker ps pour voir son statut
1
OutputCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
2
1c08a7a0d0e4 ubuntu "/bin/bash" 3 minutes ago Up 5 seconds quizzical_mcnulty
3
​
Copied!
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 :
1
docker stop quizzical_mcnulty
Copied!
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.
1
docker rm youthful_curie
Copied!
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.
1
docker commit -m "What you did to the image" -a "Author Name" container_id repository/new_image_name
Copied!
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 :
1
docker commit -m "added Node.js" -a "sammy" d9b100f2f636 sammy/ubuntu-nodejs
Copied!
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 :
1
docker images
Copied!
Vous verrez une sortie de ce type :
1
OutputREPOSITORY TAG IMAGE ID CREATED SIZE
2
sammy/ubuntu-nodejs latest 7c1f35226ca6 7 seconds ago 179MB
3
...
4
​
Copied!
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.
1
docker login -u docker-registry-username
Copied!
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 :
1
docker tag sammy/ubuntu-nodejs docker-registry-username/ubuntu-nodejs
Copied!
Ensuite, vous pouvez pousser votre propre image Ă  l'aide de :
1
docker push docker-registry-username/docker-image-name
Copied!
Pour pousser l'image ubuntu-nodejs vers le référentiel sammy, la commande serait :
1
docker push sammy/ubuntu-nodejs
Copied!
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 :
1
OutputThe push refers to a repository [docker.io/sammy/ubuntu-nodejs]
2
e3fbbfb44187: Pushed
3
5f70bf18a086: Pushed
4
a3b5c80a4eba: Pushed
5
7f18b442972b: Pushed
6
3ce512daaf78: Pushed
7
7aae4540b42d: Pushed
8
​
9
...
10
​
11
​
Copied!
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.
Nouveau listing d'images du Docker sur le Docker Hub
Si une tentative de push entraĂźne une erreur de ce type, c'est que vous ne vous ĂȘtes probablement pas connectĂ© :
1
OutputThe push refers to a repository [docker.io/sammy/ubuntu-nodejs]
2
e3fbbfb44187: Preparing
3
5f70bf18a086: Preparing
4
a3b5c80a4eba: Preparing
5
7f18b442972b: Preparing
6
3ce512daaf78: Preparing
7
7aae4540b42d: Waiting
8
unauthorized: authentication required
Copied!
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 :

Comment installer et utiliser Docker sur Ubuntu 20.04 | DigitalOcean
​