GNU/Linux >> Tutoriels Linux >  >> Panels >> Docker

Comment installer et utiliser Docker sur Ubuntu 22.04

Introduction

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 économes en ressources et plus dépendants du système d'exploitation hôte.

Pour une présentation détaillée des différents composants d'un conteneur Docker, consultez The Docker Ecosystem :An Introduction to Common Components.

Dans ce didacticiel, vous allez installer et utiliser Docker Community Edition (CE) sur Ubuntu 22.04. Vous installerez Docker lui-même, travaillerez avec des conteneurs et des images, et pousserez une image vers un référentiel Docker.

Prérequis

Pour suivre ce tutoriel, vous aurez besoin des éléments suivants :

  • Un serveur Ubuntu 22.04 configuré en suivant le guide de configuration initiale du serveur Ubuntu 22.04, y compris un sudo non racine utilisateur 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é aux étapes 7 et 8.

Étape 1 :Installation de Docker

Le package d'installation Docker disponible dans le référentiel officiel Ubuntu n'est peut-être pas la dernière version. Pour nous assurer que nous obtenons la dernière version, nous installerons Docker à partir du référentiel Docker officiel. Pour ce faire, nous allons ajouter une nouvelle source de package, ajouter la clé GPG de Docker pour nous assurer que les téléchargements sont valides, puis installer le package.

Tout d'abord, mettez à jour votre liste existante de packages :

  1. sudo apt update

Ensuite, installez quelques packages prérequis qui permettent à apt utiliser des packages via HTTPS :

  1. sudo apt install apt-transport-https ca-certificates curl software-properties-common

Ajoutez ensuite la clé GPG du référentiel Docker officiel à votre système :

  1. curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

Ajoutez le référentiel Docker aux sources APT :

  1. echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

Mettez à jour à nouveau votre liste de packages existante pour que l'ajout soit reconnu :

  1. sudo apt update

Assurez-vous que vous êtes sur le point d'installer à partir du référentiel Docker au lieu du référentiel Ubuntu par défaut :

  1. apt-cache policy docker-ce

Vous verrez une sortie comme celle-ci, bien que le numéro de version de Docker puisse être différent :

Sortie de la politique apt-cache docker-ce
docker-ce:
  Installed: (none)
  Candidate: 5:20.10.14~3-0~ubuntu-jammy
  Version table:
     5:20.10.14~3-0~ubuntu-jammy 500
        500 https://download.docker.com/linux/ubuntu jammy/stable amd64 Packages
     5:20.10.13~3-0~ubuntu-jammy 500
        500 https://download.docker.com/linux/ubuntu jammy/stable amd64 Packages

Notez que docker-ce n'est pas installé, mais le candidat à l'installation provient du référentiel Docker pour Ubuntu 22.04 (jammy ).

Enfin, installez Docker :

  1. sudo apt install docker-ce

Docker devrait maintenant être installé, le démon démarré et le processus activé pour démarrer au démarrage. Vérifiez qu'il est en cours d'exécution :

  1. sudo systemctl status docker

Le résultat doit ressembler à ce qui suit, indiquant que le service est actif et en cours d'exécution :

Output● docker.service - Docker Application Container Engine
     Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
     Active: active (running) since Fri 2022-04-01 21:30:25 UTC; 22s ago
TriggeredBy: ● docker.socket
       Docs: https://docs.docker.com
   Main PID: 7854 (dockerd)
      Tasks: 7
     Memory: 38.3M
        CPU: 340ms
     CGroup: /system.slice/docker.service
             └─7854 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock

L'installation de Docker vous donne maintenant non seulement le service Docker (démon) mais aussi le docker utilitaire de ligne de commande ou le client Docker. Nous allons explorer comment utiliser le docker commande plus loin dans ce didacticiel.

Étape 2 - Exécution de la commande Docker sans Sudo (facultatif)

Par défaut, le docker la commande ne peut être exécutée qu'à la racine utilisateur ou par un utilisateur dans le docker groupe, qui est automatiquement créé lors du processus d'installation de Docker. Si vous essayez d'exécuter le docker commande sans la préfixer avec sudo ou sans être dans le docker groupe, vous obtiendrez une sortie comme celle-ci :

Outputdocker: Cannot connect to the Docker daemon. Is the docker daemon running on this host?.
See 'docker run --help'.

Si vous voulez éviter de taper sudo chaque fois que vous exécutez le docker commande, ajoutez votre nom d'utilisateur au docker groupe :

  1. sudo usermod -aG docker ${USER}

Pour appliquer la nouvelle adhésion au groupe, déconnectez-vous du serveur et reconnectez-vous, ou saisissez ce qui suit :

  1. su - ${USER}

Vous serez invité à saisir votre mot de passe utilisateur pour continuer.

Confirmez que votre utilisateur est maintenant ajouté au docker groupez en tapant :

  1. groups
Outputsammy sudo docker

Si vous devez ajouter un utilisateur au docker groupe auquel vous n'êtes pas connecté, déclarez explicitement ce nom d'utilisateur en utilisant :

  1. sudo usermod -aG docker username

Le reste de cet article suppose que vous exécutez le docker commande en tant qu'utilisateur dans le docker grouper. Si vous choisissez de ne pas le faire, veuillez faire précéder les commandes de sudo .

Explorons le docker commande suivante.

Étape 3 - Utilisation de la commande Docker

Utilisation de docker consiste à lui passer une chaîne d'options et de commandes suivies d'arguments. La syntaxe prend cette forme :

  1. docker [option] [command] [arguments]

Pour afficher toutes les sous-commandes disponibles, tapez :

  1. docker

À partir de la version Docker 20.10.14 , la liste complète des sous-commandes disponibles comprend :

Output  attach      Attach local standard input, output, and error streams to a running container
  build       Build an image from a Dockerfile
  commit      Create a new image from a container's changes
  cp          Copy files/folders between a container and the local filesystem
  create      Create a new container
  diff        Inspect changes to files or directories on a container's filesystem
  events      Get real time events from the server
  exec        Run a command in a running container
  export      Export a container's filesystem as a tar archive
  history     Show the history of an image
  images      List images
  import      Import the contents from a tarball to create a filesystem image
  info        Display system-wide information
  inspect     Return low-level information on Docker objects
  kill        Kill one or more running containers
  load        Load an image from a tar archive or STDIN
  login       Log in to a Docker registry
  logout      Log out from a Docker registry
  logs        Fetch the logs of a container
  pause       Pause all processes within one or more containers
  port        List port mappings or a specific mapping for the container
  ps          List containers
  pull        Pull an image or a repository from a registry
  push        Push an image or a repository to a registry
  rename      Rename a container
  restart     Restart one or more containers
  rm          Remove one or more containers
  rmi         Remove one or more images
  run         Run a command in a new container
  save        Save one or more images to a tar archive (streamed to STDOUT by default)
  search      Search the Docker Hub for images
  start       Start one or more stopped containers
  stats       Display a live stream of container(s) resource usage statistics
  stop        Stop one or more running containers
  tag         Create a tag TARGET_IMAGE that refers to SOURCE_IMAGE
  top         Display the running processes of a container
  unpause     Unpause all processes within one or more containers
  update      Update configuration of one or more containers
  version     Show the Docker version information
  wait        Block until one or more containers stop, then print their exit codes

Pour afficher les options disponibles pour une commande spécifique, tapez :

  1. docker docker-subcommand --help

Pour afficher des informations à l'échelle du système sur Docker, utilisez :

  1. docker info

Explorons 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 extrait ces images de Docker Hub, un registre Docker géré par Docker, la société à l'origine du projet Docker. N'importe qui peut héberger ses images Docker sur Docker Hub, donc la plupart des applications et des distributions Linux dont vous aurez besoin auront des images hébergées là-bas.

Pour vérifier si vous pouvez accéder et télécharger des images depuis Docker Hub, saisissez :

  1. docker run hello-world

La sortie indiquera que Docker fonctionne correctement :

OutputUnable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
2db29710123e: Pull complete
Digest: sha256:bfea6278a0a267fad2634554f4f0c6f31981eea41c553fdf5a83e95a41d40c38
Status: Downloaded newer image for hello-world:latest

Hello from Docker!
This message shows that your installation appears to be working correctly.

...

Docker était initialement incapable de trouver le hello-world image localement, il a donc téléchargé l'image à partir de 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 le docker commande avec la search sous-commande. Par exemple, pour rechercher l'image Ubuntu, tapez :

  1. docker search ubuntu

Le script explorera Docker Hub et renverra une liste de toutes les images dont le nom correspond à la chaîne de recherche. Dans ce cas, la sortie ressemblera à ceci :

OutputNAME                             DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
ubuntu                           Ubuntu is a Debian-based Linux operating sys…   14048     [OK]
websphere-liberty                WebSphere Liberty multi-architecture images …   283       [OK]
ubuntu-upstart                   DEPRECATED, as is Upstart (find other proces…   112       [OK]
neurodebian                      NeuroDebian provides neuroscience research s…   88        [OK]
open-liberty                     Open Liberty multi-architecture images based…   51        [OK]
...

Dans le OFFICIEL colonne, OK indique une image construite et portée 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 en utilisant le pull sous-commande.

Exécutez la commande suivante pour télécharger le ubuntu officiel image sur votre ordinateur :

  1. docker pull ubuntu

Vous verrez le résultat suivant :

OutputUsing default tag: latest
latest: Pulling from library/ubuntu
e0b25ef51634: Pull complete
Digest: sha256:9101220a875cee98b016668342c489ff0674f247f6ca20dfc91b91c0f28581ae
Status: Downloaded newer image for ubuntu:latest
docker.io/library/ubuntu:latest

Une fois qu'une image a été téléchargée, vous pouvez ensuite exécuter un conteneur en utilisant l'image téléchargée avec le run sous-commande. Comme vous l'avez vu avec le hello-world exemple, si une image n'a pas été téléchargée lorsque docker est exécuté avec le run sous-commande, le client Docker téléchargera d'abord l'image, puis exécutera un conteneur en l'utilisant.

Pour voir les images qui ont été téléchargées sur votre ordinateur, tapez :

  1. docker images

Le résultat ressemblera à ce qui suit :

OutputREPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
ubuntu              latest              1d622ef86b13        3 weeks ago         73.9MB
hello-world         latest              bf756fb1ae65        4 months ago        13.3kB

Comme vous le verrez plus loin dans ce didacticiel, les images que vous utilisez pour exécuter des 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) à Docker Hub ou à d'autres registres Docker.

Voyons plus en détail comment exécuter des conteneurs.

Étape 5 :Exécuter un conteneur Docker

Le hello-world conteneur que vous avez exécuté à l'étape précédente est un exemple de conteneur qui s'exécute et se ferme après avoir émis un message de test. Les conteneurs peuvent être bien plus utiles que cela, et ils peuvent être interactifs. Après tout, ils sont similaires aux machines virtuelles, mais plus économes en ressources.

Par exemple, exécutons un conteneur en utilisant la dernière image d'Ubuntu. La combinaison du -i et -t switchs vous donne un accès shell interactif au conteneur :

  1. docker run -it ubuntu

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 :

Outputroot@d9b100f2f636:/#

Notez l'ID 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 souhaitez le supprimer.

Vous pouvez maintenant exécuter n'importe quelle commande à l'intérieur du conteneur. Par exemple, mettons à jour la base de données de packages à l'intérieur du conteneur. Vous n'avez pas besoin de préfixer une commande avec sudo , car vous opérez à l'intérieur du conteneur en tant que racine utilisateur :

  1. apt update

Ensuite, installez-y n'importe quelle application. Installons Node.js :

  1. apt install nodejs

Cela installe Node.js dans le conteneur à partir du référentiel officiel Ubuntu. Une fois l'installation terminée, vérifiez que Node.js est installé :

  1. node -v

Vous verrez le numéro de version affiché dans votre terminal :

Outputv12.22.9

Toutes les modifications que vous apportez à l'intérieur du conteneur ne s'appliquent qu'à ce conteneur.

Pour quitter le conteneur, tapez exit à l'invite.

Examinons ensuite la gestion des 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 afficher les actives , utilisez :

  1. docker ps

Vous verrez une sortie semblable à la suivante :

OutputCONTAINER ID        IMAGE               COMMAND             CREATED

Dans ce didacticiel, vous avez démarré deux conteneurs ; un du hello-world image et une autre de ubuntu image. Les deux conteneurs ne sont plus en cours d'exécution, mais ils existent toujours sur votre système.

Pour afficher tous les conteneurs - actifs et inactifs, exécutez docker ps avec le -a commutateur :

  1. docker ps -a

Vous verrez une sortie semblable à celle-ci :

OutputCONTAINER ID   IMAGE         COMMAND   CREATED         STATUS                     PORTS     NAMES
1c08a7a0d0e4   ubuntu        "bash"     About a minute ago   Exited (0) 7 seconds ago             dazzling_taussig
587000e49d53   hello-world   "/hello"   5 minutes ago        Exited (0) 5 minutes ago             adoring_kowalevski

Pour afficher le dernier conteneur que vous avez créé, transmettez-lui le -l commutateur :

  1. docker ps -l
OutputCONTAINER ID   IMAGE     COMMAND   CREATED         STATUS                     PORTS     NAMES
1c08a7a0d0e4   ubuntu    "bash"    3 minutes ago   Exited (0) 2 minutes ago             dazzling_taussig

Pour démarrer un conteneur arrêté, utilisez docker start , suivi de l'ID du conteneur ou du nom du conteneur. Commençons le conteneur basé sur Ubuntu avec l'ID de 1c08a7a0d0e4 :

  1. docker start 1c08a7a0d0e4

Le conteneur va démarrer et vous pouvez utiliser docker ps pour voir son statut :

OutputCONTAINER ID   IMAGE     COMMAND   CREATED         STATUS         PORTS     NAMES
1c08a7a0d0e4   ubuntu    "bash"    6 minutes ago   Up 8 seconds             dazzling_taussig

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

  1. docker stop dazzling_taussig

Une fois que vous avez décidé que vous n'avez plus besoin d'un conteneur, supprimez-le avec le docker rm commande, en utilisant à nouveau l'ID du conteneur ou le nom. Utilisez le docker ps -a commande pour trouver l'ID ou le nom du conteneur associé au hello-world image et supprimez-la.

  1. docker rm adoring_kowalevski

Vous pouvez démarrer un nouveau conteneur et lui donner un nom en utilisant le --name interrupteur. Vous pouvez également utiliser le --rm commutateur pour créer un conteneur qui se supprime lorsqu'il est arrêté. Voir l'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 créer de nouveaux conteneurs. Voyons comment cela fonctionne.

Étape 7 – Valider les modifications d'un conteneur sur une image Docker

Lorsque vous démarrez une image Docker, vous pouvez créer, modifier et supprimer des fichiers comme vous le feriez 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'avez détruit avec le docker rm commande, les modifications seront définitivement perdues.

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 fonctionnant à partir d'une image, mais le conteneur est différent de l'image que vous avez utilisée pour le créer. Mais vous voudrez peut-être réutiliser ce conteneur Node.js comme base pour de nouvelles images plus tard.

Validez ensuite 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

Le -m switch est pour le message de validation qui vous aide, vous et les autres, à savoir quelles modifications vous avez apportées, tandis que -a est utilisé pour spécifier l'auteur. Le container_id est celui que vous avez noté précédemment dans le didacticiel lorsque vous avez démarré la session Docker interactive. Sauf si vous avez créé des dépôts supplémentaires sur Docker Hub, le repository 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

Quand vous commettez une image, la nouvelle image est enregistrée localement sur votre ordinateur. Plus loin dans ce didacticiel, vous apprendrez à transférer une image vers un registre Docker tel que Docker Hub afin que d'autres puissent y accéder.

La nouvelle liste des images Docker affichera la nouvelle image, ainsi que l'ancienne dont elle est dérivée :

  1. docker images

Vous verrez une sortie comme celle-ci :

OutputREPOSITORY               TAG                 IMAGE ID            CREATED             SIZE
sammy/ubuntu-nodejs   latest              7c1f35226ca6        7 seconds ago       179MB
...

Dans cet exemple, ubuntu-nodejs est la nouvelle image, qui a été dérivée de l'existant ubuntu image de Docker Hub. La différence de taille reflète les modifications apportées. Et dans cet exemple, le changement était que NodeJS était installé. Ainsi, la prochaine fois que vous aurez besoin d'exécuter un conteneur à l'aide d'Ubuntu avec NodeJS préinstallé, vous pourrez simplement utiliser la nouvelle image.

Vous pouvez également créer des images à partir d'un Dockerfile , qui vous permet d'automatiser l'installation du logiciel dans une nouvelle image. Cependant, cela sort du cadre de ce didacticiel.

Partageons maintenant la nouvelle image avec d'autres personnes afin qu'elles puissent créer des conteneurs à partir de celle-ci.

Étape 8 :Transférer des images Docker vers un référentiel Docker

La prochaine étape logique après la création d'une nouvelle image à partir d'une image existante consiste à la partager avec quelques-uns de vos amis, le monde entier sur Docker Hub ou un 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.

Pour envoyer votre image, connectez-vous d'abord à Docker Hub.

  1. docker login -u docker-registry-username

Vous serez invité à vous authentifier à l'aide de votre mot de passe Docker Hub. Si vous avez spécifié le mot de passe correct, l'authentification devrait réussir.

Remarque : Si votre nom d'utilisateur de registre Docker est différent du nom d'utilisateur local que vous avez utilisé pour créer l'image, vous devrez marquer votre image avec votre nom d'utilisateur de registre. Pour l'exemple donné à la dernière étape, vous taperiez :

  1. docker tag sammy/ubuntu-nodejs docker-registry-username/ubuntu-nodejs

Ensuite, vous pouvez pousser votre propre image en utilisant :

  1. docker push docker-registry-username/docker-image-name

Pour pousser le ubuntu-nodejs image au sammy dépôt, la commande serait :

  1. docker push sammy/ubuntu-nodejs

Le processus peut prendre un certain temps car il télécharge les images, mais une fois terminé, le résultat ressemblera à ceci :

OutputThe push refers to a repository [docker.io/sammy/ubuntu-nodejs]
e3fbbfb44187: Pushed
5f70bf18a086: Pushed
a3b5c80a4eba: Pushed
7f18b442972b: Pushed
3ce512daaf78: Pushed
7aae4540b42d: Pushed

...


Après avoir poussé une image vers un registre, elle devrait être répertoriée sur le tableau de bord de votre compte, comme le montre l'image ci-dessous.

Si une tentative de push aboutit à une erreur de ce type, vous ne vous êtes probablement pas connecté :

OutputThe push refers to a repository [docker.io/sammy/ubuntu-nodejs]
e3fbbfb44187: Preparing
5f70bf18a086: Preparing
a3b5c80a4eba: Preparing
7f18b442972b: Preparing
3ce512daaf78: Preparing
7aae4540b42d: Waiting
unauthorized: authentication required

Connectez-vous avec docker login et répétez la tentative de poussée. Vérifiez ensuite qu'il existe sur votre page de référentiel Docker Hub.

Vous pouvez maintenant utiliser docker pull sammy/ubuntu-nodejs pour extraire l'image vers une nouvelle machine et l'utiliser pour exécuter un nouveau conteneur.

Conclusion

Dans ce didacticiel, vous avez installé Docker, travaillé avec des images et des conteneurs, et transmis une image modifiée à Docker Hub. Maintenant que vous connaissez les bases, explorez les autres didacticiels Docker de la communauté DigitalOcean.


Docker
  1. Comment installer et utiliser Docker sur Ubuntu 20.04

  2. Comment installer et utiliser Wine sur Ubuntu 20.04

  3. Comment installer et utiliser Docker sur Ubuntu 18.04

  4. Comment installer et utiliser Docker Compose sur Ubuntu 18.04

  5. Comment installer et utiliser Docker dans Ubuntu 20.04

Comment installer et utiliser iTunes sur Ubuntu 20.04

Comment installer et utiliser R sur Ubuntu

Comment installer et utiliser Docker Compose sur Ubuntu 20.04

Comment installer et utiliser Docker Compose sur Ubuntu 22.04

Comment installer et utiliser Docker sur Ubuntu (dans le monde réel)

Comment installer et utiliser Docker sur Ubuntu 20.04