Docker (logiciel)

Docker est une plateforme permettant de lancer certaines applications dans des conteneurs logiciels.

Pour les articles homonymes, voir Docker (homonymie).

Docker

Informations
Créateur Solomon Hykes
Développé par Docker, Inc. (en)
Dépôt github.com/moby/moby
État du projet En développement actif
Écrit en Go
Système d'exploitation Linux, Microsoft Windows, macOS et type Unix
Environnement Multi-plateforme
Formats lus Dockerfile (d)
Formats écrits Dockerfile (d)
Type Conteneur
Politique de distribution Parfois gratuit
Licence Licence Apache version 2.0 et licence propriétaire
Site web www.docker.com

Selon la firme de recherche sur l'industrie 451 Research, « Docker est un outil qui peut empaqueter une application et ses dépendances dans un conteneur isolé, qui pourra être exécuté sur n'importe quel serveur ». Il ne s'agit pas de virtualisation, mais de conteneurisation, une forme plus légère qui s'appuie sur certaines parties de la machine hôte pour son fonctionnement. Cette approche permet d'accroître la flexibilité et la portabilité d’exécution d'une application, laquelle va pouvoir tourner de façon fiable et prévisible sur une grande variété de machines hôtes, que ce soit sur la machine locale, un cloud privé ou public, une machine nue, etc.[1]

Techniquement, Docker étend le format de conteneur Linux standard, LXC, avec une API de haut niveau fournissant une solution pratique de virtualisation qui exécute les processus de façon isolée[2]. Pour arriver à ses fins, Docker utilise entre autres LXC, cgroups et le noyau Linux lui-même[1]. Contrairement aux machines virtuelles traditionnelles, un conteneur Docker n'inclut pas de système d'exploitation, mais s'appuie au contraire sur les fonctionnalités du système d’exploitation fournies par la machine hôte[3].

La technologie de conteneur de Docker peut être utilisée pour étendre des systèmes distribués de façon qu'ils s'exécutent de manière autonome depuis une seule machine physique ou une seule instance par nœud. Cela permet aux nœuds d'être déployés au fur et à mesure que les ressources sont disponibles, offrant un déploiement transparent et similaire aux PaaS pour des systèmes comme Apache Cassandra, Riak ou d'autres systèmes distribués[4].

Vue d’ensemble

Schéma des interfaces de Docker

Docker permet la mise en œuvre de conteneurs s'exécutant en isolation, via une API de haut-niveau. Construit sur des capacités du noyau Linux (surtout les cgroups et espaces de nommage), un conteneur Docker, à l'opposé de machines virtuelles traditionnelles, ne requiert aucun système d'exploitation séparé et n'en fournit aucun. Il s'appuie plutôt sur les fonctionnalités du noyau et utilise l'isolation de ressources (comme le processeur, la mémoire, les entrées et sorties et les connexions réseau) ainsi que des espaces de noms séparés pour isoler le système d'exploitation tel que vu par l'application. Docker accède aux capacités de virtualisation du noyau Linux, soit directement à travers la bibliothèque runc (disponible depuis Docker 0.9), soit indirectement via libvirt, LXC (Linux Containers) ou systemd-nspawn.

Utiliser Docker pour créer et gérer des conteneurs peut simplifier la mise en œuvre de systèmes distribués en permettant à de multiples applications, tâches de fond et autres processus de s'exécuter de façon autonome sur une seule machine physique ou à travers un éventail de machines isolées. Ceci permet de déployer des nœuds en tant que ressources sur besoin, fournissant ainsi une plateforme de déploiement de style PAAS et la scalabilité de systèmes tels Apache Cassandra, MongoDB ou Riak, ainsi que la simplification de la création et maintenance de queues de tâches ou autres systèmes distribués.

La notion de conteneur

L'objectif d'un conteneur est le même que pour un serveur dédié virtuel : héberger des services sur un même serveur physique tout en les isolant les uns des autres. Un conteneur est cependant moins figé qu'une machine virtuelle en matière de taille de disque et de ressources allouées.

Un conteneur permet d'isoler chaque service : le serveur web, la base de données, des applications pouvant être exécutées de façon indépendante dans leur conteneur dédié, contenant uniquement les dépendances nécessaires. Chaque conteneur peut être relié aux autres par des réseaux virtuels. Il est possible de monter des volumes de disque de la machine hôte dans un conteneur. Si aucun processus n'est démarré dans le conteneur, alors celui-ci s'arrête. On parle parfois de virtualisation d'OS : contrairement à la virtualisation qui émule par logiciel différentes machines sur une machine physique, la conteneurisation émule différents OS sur un seul OS.

Histoire

Docker est développé par Solomon Hykes pour un projet interne de dotCloud, une entreprise française proposant une plate-forme en tant que service, avec les contributions d'Andrea Luzzardi et Francois-Xavier Bourlet, également employés de dotCloud. Docker est une évolution basée sur les technologies propriétaires de dotCloud, elles-mêmes construites sur des projets open source.

Docker est distribué en tant que projet open source à partir de mars 2013[2].

Il s'agit actuellement du moteur de conteneurisation le plus utilisé. Un grand avantage de Docker est la possibilité de modéliser chaque conteneur sous la forme d'une image que l'on peut stocker localement ou sur le Docker Hub, endroit public où de nombreuses images sont publiées et mises à jour régulièrement.

En 2019 est annoncée la version 3 de la plateforme Docker lors de la conférence DockerCon 2019[5]. En novembre 2019, la société Docker revend son produit « Docker Enterprise » à Mirantis, et effectue une levée de fonds de près de 35 millions de dollars[6].

Intégration avec d'autres systèmes

L'intégration de Docker a été faite avec les outils de gestion d'infrastructures suivants :

Le 19 septembre 2013, Red Hat et Docker ont annoncé une collaboration concernant Fedora, Red Hat Enterprise Linux et Openshift[16]. En mai 2015, Synology, un constructeur de NAS, intègre Docker dans son logiciel interne DSM v5.2[17].

Références

  1. Katherine Noyes, « Docker: A 'Shipping Container' for Linux Code », Linux, (consulté le )
  2. Abel Avram, « Docker: Automated and Consistent Software Deployments », InfoQ, (consulté le )
  3. Alex Williams, « The Matrix Of Hell And Two Open-Source Projects For The Emerging Agnostic Cloud », TechCrunch, (consulté le )
  4. Adron Hall, « OSCON : Conversations, Deployments, Architecture, Docker and the Future? », CloudAve, (consulté le )
  5. « Docker : une plateforme 3.0 pour lier toujours plus les développeurs aux containers… et à Kubernetes », sur LeMagIT (consulté le )
  6. « Que devient Docker ? », sur Journal du Net,
  7. Ansible, Inc., « Ansible and Docker », sur www.ansible.com (consulté le )
  8. (en) « thoward/docker-cookbook », sur GitHub (consulté le )
  9. (en) « garethr/docker · Puppet Forge », sur forge.puppetlabs.com (consulté le )
  10. (en) « containers docker registry », sur www.inedo.com (consulté le )
  11. (en) « Using SaltStack in production to manage Docker application containers », sur saltstack.com,
  12. https://github.com/philspitler/vagrant-docker
  13. (en) « georgebashi/jenkins-docker-plugin », sur GitHub (consulté le )
  14. (en) « OpenStack Community Weekly Newsletter (May 31 – June 7) », sur www.openstack.org, (consulté le )
  15. (en) « OpenSVC documentation — OpenSVC documentation », sur docs.opensvc.com (consulté le )
  16. (en) Alex Williams, « DotCloud Pivots And Wins Big With Docker, The Cloud Service Now Part Of Red Hat OpenShift », (consulté le )
  17. http://www.cachem.fr/synology-dsm-5-2-disponible-version-finale/ DSM v5.2

Annexes

Articles connexes

Liens externes

  • Portail des entreprises
  • Portail GNU/Linux
  • Portail des logiciels libres
  • Portail de l’informatique
Cet article est issu de Wikipedia. Le texte est sous licence Creative Commons - Attribution - Partage dans les Mêmes. Des conditions supplémentaires peuvent s'appliquer aux fichiers multimédias.