SlideShare une entreprise Scribd logo
1  sur  40
Télécharger pour lire hors ligne
Docker, mais qu’est-ce que
c’est ?
Introduction à Docker et son écosystème
Qui suis-je ?
Julien Maitrehenry
DevOps, Cloud Architect, Développeur
Co-fondateur @Kumojin
Kumojin.com
Github.com/jmaitrehenry
jmaitrehenry.ca
Agenda
• Qu’est-ce que Docker ?
• Docker Compose
• Orchestration
• Docker Desktop
• Questions ?
Photo by Ian Taylor on Unsplash
Qu’est-ce
que Docker ?
Mais que
signifie
« Docker » ?
• Le projet d’une communauté Open Source
• Les outils issus de ce projet
• L’entreprise Docker inc.
Mais à quoi
ça sert ?
Au commencement
• Un seul but
• Communauté des développeurs
sous linux seulement
• Un gros binaire
Et maintenant ?
• Linux et Windows
• Multi Architecture (intel, armv5-8, ppc, i386)
• Docker utilise plusieurs composants séparés
• Standardisation des composants (OCI, CNCF)
• Adopté par une large majorité des clouds
Qu’est-ce qu’un
conteneur ?
• Un espace isolé où s’exécute une application
• L’espace isolé contient toutes les libs pour
rouler son application
• Possède sa propre stack réseau, ses users, ses
processus
• Partage le kernel de l’hôte
• Peut avoir des restrictions sur l’utilisation des
ressources (CPU, Ram, etc)
En quoi c’est différent d’une VM ?
Comment
créer un
conteneur ?
Qu’est-ce
qu’une
image?
• Un ensemble de couche
• Chaque couche est immutable
• Chaque couche est réutilisable
Construisons une image docker
Image de base
Variable d’environnement
Variable définie lors du build
Dossier de travail – alias dossier courant
Copie de fichiers dans l’image
Commande executée lors du build
Copie du dossier dans l’image
Commande par défaut qui sera
executée lors d’un docker run
Comment transformer notre fichier en image ?
❯ docker build -t myapp:v1.0.0 --build-arg NODE_ENV=development .
Commande pour construire une image
Donner un nom et un tag à l’image
Passer une variable de build
Contexte du build
Si le fichier Dockerfile porte un autre nom ou est situé ailleurs, il faut le spécifier avec :
-f .docker/Dockerfile
Attention : le contexte de build est toujours le dernier paramètre
Comment lancer un conteneur ?
- Je ne peux pas accéder à l’app depuis mon navigateur
- Ctr+C n’arrête pas l’app
- Le nom du conteneur va être généré aléatoirement (ex: goofy_kapitsa)
❯ docker run myapp:v1.0.0
Commande pour exécuter un container Nom de l’image et son tag
Comment lancer un conteneur ?
❯ docker run –ti -p 8080:80 --name myapp myapp:v1.0.0
Exécute en mode intéractif et avec un tty
Lie le port 80 du container au port 8080 du host
Donne le nom myapp au container
Comment lancer un conteneur ?
❯ docker run –d -p 8080:80 --name myapp myapp:v1.0.0
Lance le container en arrière plan
❯ docker run –ti –p 8080:80 --name myapp --rm myapp:v1.0.0 bash
Supprime automatiquement le conteneur quand il sera arrêté
Change la commande par défaut (CMD)
Recap
Docker Engine
• Application Client-Server pour:
• Gérer des images
• Gérer des conteneurs
• Gérer des réseaux
• Gérer des volumes
• Possède une API REST et un CLI
Volume
• Conserver des données en dehors du
conteneur
• Partager des données avec l’hôte
• D’autres drivers possibles
This Photo by Unknown Author is licensed under CC BY-SA-NC
Partager un dossier/fichier entre le host et le conteneur
❯ docker run -ti --rm -v `pwd`/mydir:/data ubuntu
Instruction pour utiliser un volume
Dossier local sur l’host Dossier dans le conteneur
Attention dans le cas où l’on monte un fichier !
Les modifications au fichier peuvent ne pas être reflétées dans le conteneur
Ex: sed, vim, etc
Utilisation d’un volume
❯ docker volume create mydata
❯ docker run -ti --rm -v mydata:/data ubuntu
Sous commande pour gérer les volumes Nom du volume
Nom du volume au lieu du path local
Network
• Permet de créer des réseaux isolés
• Les conteneurs peuvent communiquer entre
eux par nom de container, id ou alias
• Plusieurs drivers disponibles :
• Bridge (default)
• Internal
• None
• Host
Internal network
❯ docker network create --internal intnet
❯ docker run --network intnet curlimages/curl -m3 https://google.com
╰─❯ curl: (28) Resolving timed out after 3002 milliseconds
Sous commande pour gérer les réseaux Type de réseau Nom du réseau
Attache le conteneur au réseau intnet
Communication intra conteneur
❯ docker network create --driver bridge mynet
❯ docker run -d --network mynet --name nginx --network-alias web nginx
❯ docker run --rm --network mynet curlimages/curl -m3 http://web
Utilise un driver réseau sécifique
Ajoute un alias au conteneur dans les réseaux où il est connecté
Le nom et l’ID du conteneur fonctionne aussi
Autres réseaux utiles
❯ docker run --rm --network none curl -m3 https://google.com
❯ docker run –d --network host nginx
Sans isolation réseau entre le conteneur et l’hôte
Sans réseau
Docker
Compose
Construisons un fichier docker compose
Version du format du fichier
Définition des services, alias des conteneurs
Définition des réseaux
Définition des volumes
Construisons un fichier docker compose
Nom du service ainsi que de son nom sur les réseaux
Image docker du conteneur
Si le containeur crash, docker le relance
Liste des volumes à attacher au conteneur
Liste des variables d’environnement
Liste des réseaux à attacher au conteneur
Construisons un fichier docker compose
Surcharge de la commande par défaut de l’image
On peut attacher un volume dans un dossier d’un autre volume
Définition pour construire l’image Docker
Créer une dépendance à un autre service
Liste des ports à lier sur le host
Construisons un fichier docker compose
Sur un réseau séparé de la base de données
Comment utiliser un un fichier compose ?
❯ docker compose ps -a
Liste les conteneurs créer par compose Incluant ceux arrêtés
❯ docker compose logs -f [nom du/des service(s)]
Affiche les logs Et affiche les nouveaux messages au fur et à mesure
❯ docker compose up –d [nom du/des service(s)]
Sous commande pour gérer compose Lance un/des services/tous les services
En background
Registry Docker
• Héberge les images Docker
• Nombreux Registry en ligne disponibles:
• Docker Hub
• Azure ACR
• AWS ECR
• Github Registry
• …
• Nombreuses solutions self-hosted:
• Docker Registry
• Nexus
• Artifactory
• …
Commandes utiles
❯ docker login / docker login kumojin.azurecr.io
Connecte Docker à un registry
Télécharge une image dans un registry
Pousse une image du registry localement
❯ docker push jmaitrehenry/myimage
❯ docker pull kumojin.azurecr.io/myapp/api:v1.0.0
Se connecte à un registry spécifique
Orchestration
• Pourquoi faire ?
• Outils d’orchestration
• Solutions cloud
Pour quoi
faire ?
• Approvisionnement et placement des
containeurs
• Mécanisme de healthcheck et métriques
• Gestion des indisponibilités et scalabilité
• Gestion des déploiements
• Service discovery et gestion du réseau
• Et plus encore !
Outils d’orchestration
Solutions
Cloud
• Basé sur Kubernetes
• Azure: AKS
• AWS: EKS
• Google: GKE
• Basée sur des conteneurs
• Azure ACI
• AWS Fargate
• AWS ECS
Docker
Desktop
Qu’est-ce que c’est ?
Qu’est-ce que cela apporte ?
Questions ?

Contenu connexe

Tendances

Tadx - Présentation Conteneurisation
Tadx -  Présentation ConteneurisationTadx -  Présentation Conteneurisation
Tadx - Présentation ConteneurisationTADx
 
Alphorm.com Formation Kubernetes : Installation et Configuration
Alphorm.com Formation Kubernetes : Installation et ConfigurationAlphorm.com Formation Kubernetes : Installation et Configuration
Alphorm.com Formation Kubernetes : Installation et ConfigurationAlphorm
 
Docker Tours Meetup #1 - Introduction à Docker
Docker Tours Meetup #1 - Introduction à DockerDocker Tours Meetup #1 - Introduction à Docker
Docker Tours Meetup #1 - Introduction à DockerThibaut Marmin
 
Présentation DEVOPS.pptx
Présentation DEVOPS.pptxPrésentation DEVOPS.pptx
Présentation DEVOPS.pptxboulonvert
 
Journée DevOps : La boite à outil d'une équipe DevOps
Journée DevOps : La boite à outil d'une équipe DevOpsJournée DevOps : La boite à outil d'une équipe DevOps
Journée DevOps : La boite à outil d'une équipe DevOpsPublicis Sapient Engineering
 
Introduction à DevOps
Introduction à DevOpsIntroduction à DevOps
Introduction à DevOpsMicrosoft
 
Sw 100 fr docker conteneurisation des applications
Sw 100 fr docker conteneurisation des applicationsSw 100 fr docker conteneurisation des applications
Sw 100 fr docker conteneurisation des applicationsStephane Woillez
 
Docker 101: An Introduction
Docker 101: An IntroductionDocker 101: An Introduction
Docker 101: An IntroductionPOSSCON
 
Getting started with Docker
Getting started with DockerGetting started with Docker
Getting started with DockerRavindu Fernando
 
Cours Devops Sparks.pptx.pdf
Cours Devops Sparks.pptx.pdfCours Devops Sparks.pptx.pdf
Cours Devops Sparks.pptx.pdfboulonvert
 
Presentation DevOps : enjeux , objectifs, consequences
Presentation DevOps : enjeux , objectifs, consequencesPresentation DevOps : enjeux , objectifs, consequences
Presentation DevOps : enjeux , objectifs, consequencesStéphane Di Cioccio
 
Docker intro
Docker introDocker intro
Docker introOleg Z
 
Dockers and containers basics
Dockers and containers basicsDockers and containers basics
Dockers and containers basicsSourabh Saxena
 

Tendances (20)

Tadx - Présentation Conteneurisation
Tadx -  Présentation ConteneurisationTadx -  Présentation Conteneurisation
Tadx - Présentation Conteneurisation
 
Alphorm.com Formation Kubernetes : Installation et Configuration
Alphorm.com Formation Kubernetes : Installation et ConfigurationAlphorm.com Formation Kubernetes : Installation et Configuration
Alphorm.com Formation Kubernetes : Installation et Configuration
 
Docker Tours Meetup #1 - Introduction à Docker
Docker Tours Meetup #1 - Introduction à DockerDocker Tours Meetup #1 - Introduction à Docker
Docker Tours Meetup #1 - Introduction à Docker
 
Présentation DEVOPS.pptx
Présentation DEVOPS.pptxPrésentation DEVOPS.pptx
Présentation DEVOPS.pptx
 
Intro docker
Intro dockerIntro docker
Intro docker
 
Journée DevOps : La boite à outil d'une équipe DevOps
Journée DevOps : La boite à outil d'une équipe DevOpsJournée DevOps : La boite à outil d'une équipe DevOps
Journée DevOps : La boite à outil d'une équipe DevOps
 
What is Docker
What is Docker What is Docker
What is Docker
 
Introduction à DevOps
Introduction à DevOpsIntroduction à DevOps
Introduction à DevOps
 
kubernetes, pourquoi et comment
kubernetes, pourquoi et commentkubernetes, pourquoi et comment
kubernetes, pourquoi et comment
 
Docker Basics
Docker BasicsDocker Basics
Docker Basics
 
Sw 100 fr docker conteneurisation des applications
Sw 100 fr docker conteneurisation des applicationsSw 100 fr docker conteneurisation des applications
Sw 100 fr docker conteneurisation des applications
 
Docker 101: An Introduction
Docker 101: An IntroductionDocker 101: An Introduction
Docker 101: An Introduction
 
Getting started with Docker
Getting started with DockerGetting started with Docker
Getting started with Docker
 
Docker Introduction
Docker IntroductionDocker Introduction
Docker Introduction
 
Cours Devops Sparks.pptx.pdf
Cours Devops Sparks.pptx.pdfCours Devops Sparks.pptx.pdf
Cours Devops Sparks.pptx.pdf
 
Docker Introduction
Docker IntroductionDocker Introduction
Docker Introduction
 
Presentation DevOps : enjeux , objectifs, consequences
Presentation DevOps : enjeux , objectifs, consequencesPresentation DevOps : enjeux , objectifs, consequences
Presentation DevOps : enjeux , objectifs, consequences
 
DEVOPS
DEVOPSDEVOPS
DEVOPS
 
Docker intro
Docker introDocker intro
Docker intro
 
Dockers and containers basics
Dockers and containers basicsDockers and containers basics
Dockers and containers basics
 

Similaire à Docker, mais qu’est-ce que c’est ?

Oxalide Workshop #4 - Docker, des tours dans le petit bassin
Oxalide Workshop #4 - Docker, des tours dans le petit bassinOxalide Workshop #4 - Docker, des tours dans le petit bassin
Oxalide Workshop #4 - Docker, des tours dans le petit bassinLudovic Piot
 
Oxalide Workshop #4 - Docker, des tours dans le petit bassin
Oxalide Workshop #4 - Docker, des tours dans le petit bassinOxalide Workshop #4 - Docker, des tours dans le petit bassin
Oxalide Workshop #4 - Docker, des tours dans le petit bassinOxalide
 
docker-workshop-by-rbk.pdf jhuhiuguigugyug
docker-workshop-by-rbk.pdf jhuhiuguigugyugdocker-workshop-by-rbk.pdf jhuhiuguigugyug
docker-workshop-by-rbk.pdf jhuhiuguigugyugamine17157
 
Docker nice meetup #1 construire, déployer et exécuter vos applications, ...
Docker nice meetup #1   construire, déployer et exécuter vos applications, ...Docker nice meetup #1   construire, déployer et exécuter vos applications, ...
Docker nice meetup #1 construire, déployer et exécuter vos applications, ...adri1s
 
Geek Time Mars 2017 : Workshop Docker
Geek Time Mars 2017 : Workshop DockerGeek Time Mars 2017 : Workshop Docker
Geek Time Mars 2017 : Workshop DockerNizar GARRACHE
 
Gab17 lyon-Docker pour quoi faire - Cédric Leblond et Derue
Gab17 lyon-Docker pour quoi faire - Cédric Leblond et DerueGab17 lyon-Docker pour quoi faire - Cédric Leblond et Derue
Gab17 lyon-Docker pour quoi faire - Cédric Leblond et DerueAZUG FR
 
A la découverte de docker
A la découverte de dockerA la découverte de docker
A la découverte de dockerjean pasqualini
 
5390997 Support formation : Construire et administrer vos conteneurs avec Doc...
5390997 Support formation : Construire et administrer vos conteneurs avec Doc...5390997 Support formation : Construire et administrer vos conteneurs avec Doc...
5390997 Support formation : Construire et administrer vos conteneurs avec Doc...AbdellahELMAMOUN
 
Introduction à Docker et utilisation en production /Digital apéro Besançon [1...
Introduction à Docker et utilisation en production /Digital apéro Besançon [1...Introduction à Docker et utilisation en production /Digital apéro Besançon [1...
Introduction à Docker et utilisation en production /Digital apéro Besançon [1...Silicon Comté
 
709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx
709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx
709469716-Docker-Intro.pptx709469716-Docker-Intro.pptxAbdellahELMAMOUN
 
Docker - un outil pour faciliter le développement et le déploiement informatique
Docker - un outil pour faciliter le développement et le déploiement informatiqueDocker - un outil pour faciliter le développement et le déploiement informatique
Docker - un outil pour faciliter le développement et le déploiement informatiquesdenier
 
A la découverte de docker, 2ème partie
A la découverte de docker, 2ème partieA la découverte de docker, 2ème partie
A la découverte de docker, 2ème partieSamuel Desseaux
 
Support : introduction à docker
Support : introduction à dockerSupport : introduction à docker
Support : introduction à dockerBoubker ABERWAG
 
Introduction à docker.io
Introduction à docker.ioIntroduction à docker.io
Introduction à docker.ioNicolas Hennion
 
optimadata.nl-Comment exécuter Postgres sur Docker partie 1.pdf
optimadata.nl-Comment exécuter Postgres sur Docker partie 1.pdfoptimadata.nl-Comment exécuter Postgres sur Docker partie 1.pdf
optimadata.nl-Comment exécuter Postgres sur Docker partie 1.pdfPascal Ponzoni
 
JFTL-2018-Comment-mettre-en-place-des-plateformes-de-test-gr__ce-__-Docker.pptx
JFTL-2018-Comment-mettre-en-place-des-plateformes-de-test-gr__ce-__-Docker.pptxJFTL-2018-Comment-mettre-en-place-des-plateformes-de-test-gr__ce-__-Docker.pptx
JFTL-2018-Comment-mettre-en-place-des-plateformes-de-test-gr__ce-__-Docker.pptxAnisSalhi3
 
Docker en Production (Docker Paris)
Docker en Production (Docker Paris)Docker en Production (Docker Paris)
Docker en Production (Docker Paris)Jérôme Petazzoni
 

Similaire à Docker, mais qu’est-ce que c’est ? (20)

Docker - YaJUG
Docker  - YaJUGDocker  - YaJUG
Docker - YaJUG
 
Oxalide Workshop #4 - Docker, des tours dans le petit bassin
Oxalide Workshop #4 - Docker, des tours dans le petit bassinOxalide Workshop #4 - Docker, des tours dans le petit bassin
Oxalide Workshop #4 - Docker, des tours dans le petit bassin
 
Oxalide Workshop #4 - Docker, des tours dans le petit bassin
Oxalide Workshop #4 - Docker, des tours dans le petit bassinOxalide Workshop #4 - Docker, des tours dans le petit bassin
Oxalide Workshop #4 - Docker, des tours dans le petit bassin
 
docker-workshop-by-rbk.pdf jhuhiuguigugyug
docker-workshop-by-rbk.pdf jhuhiuguigugyugdocker-workshop-by-rbk.pdf jhuhiuguigugyug
docker-workshop-by-rbk.pdf jhuhiuguigugyug
 
Docker nice meetup #1 construire, déployer et exécuter vos applications, ...
Docker nice meetup #1   construire, déployer et exécuter vos applications, ...Docker nice meetup #1   construire, déployer et exécuter vos applications, ...
Docker nice meetup #1 construire, déployer et exécuter vos applications, ...
 
Geek Time Mars 2017 : Workshop Docker
Geek Time Mars 2017 : Workshop DockerGeek Time Mars 2017 : Workshop Docker
Geek Time Mars 2017 : Workshop Docker
 
Gab17 lyon-Docker pour quoi faire - Cédric Leblond et Derue
Gab17 lyon-Docker pour quoi faire - Cédric Leblond et DerueGab17 lyon-Docker pour quoi faire - Cédric Leblond et Derue
Gab17 lyon-Docker pour quoi faire - Cédric Leblond et Derue
 
A la découverte de docker
A la découverte de dockerA la découverte de docker
A la découverte de docker
 
5390997 Support formation : Construire et administrer vos conteneurs avec Doc...
5390997 Support formation : Construire et administrer vos conteneurs avec Doc...5390997 Support formation : Construire et administrer vos conteneurs avec Doc...
5390997 Support formation : Construire et administrer vos conteneurs avec Doc...
 
Introduction à Docker et utilisation en production /Digital apéro Besançon [1...
Introduction à Docker et utilisation en production /Digital apéro Besançon [1...Introduction à Docker et utilisation en production /Digital apéro Besançon [1...
Introduction à Docker et utilisation en production /Digital apéro Besançon [1...
 
709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx
709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx
709469716-Docker-Intro.pptx709469716-Docker-Intro.pptx
 
Docker - un outil pour faciliter le développement et le déploiement informatique
Docker - un outil pour faciliter le développement et le déploiement informatiqueDocker - un outil pour faciliter le développement et le déploiement informatique
Docker - un outil pour faciliter le développement et le déploiement informatique
 
Prise en main de Docker
Prise en main de DockerPrise en main de Docker
Prise en main de Docker
 
A la découverte de docker, 2ème partie
A la découverte de docker, 2ème partieA la découverte de docker, 2ème partie
A la découverte de docker, 2ème partie
 
Support : introduction à docker
Support : introduction à dockerSupport : introduction à docker
Support : introduction à docker
 
Introduction à docker.io
Introduction à docker.ioIntroduction à docker.io
Introduction à docker.io
 
optimadata.nl-Comment exécuter Postgres sur Docker partie 1.pdf
optimadata.nl-Comment exécuter Postgres sur Docker partie 1.pdfoptimadata.nl-Comment exécuter Postgres sur Docker partie 1.pdf
optimadata.nl-Comment exécuter Postgres sur Docker partie 1.pdf
 
Docker@linuq
Docker@linuqDocker@linuq
Docker@linuq
 
JFTL-2018-Comment-mettre-en-place-des-plateformes-de-test-gr__ce-__-Docker.pptx
JFTL-2018-Comment-mettre-en-place-des-plateformes-de-test-gr__ce-__-Docker.pptxJFTL-2018-Comment-mettre-en-place-des-plateformes-de-test-gr__ce-__-Docker.pptx
JFTL-2018-Comment-mettre-en-place-des-plateformes-de-test-gr__ce-__-Docker.pptx
 
Docker en Production (Docker Paris)
Docker en Production (Docker Paris)Docker en Production (Docker Paris)
Docker en Production (Docker Paris)
 

Plus de Julien Maitrehenry

Comment maitriser git et produire de beaux commits
Comment maitriser git et produire de beaux commitsComment maitriser git et produire de beaux commits
Comment maitriser git et produire de beaux commitsJulien Maitrehenry
 
Global Azure Bootcamp Québec - Container on Azure
Global Azure Bootcamp Québec - Container on AzureGlobal Azure Bootcamp Québec - Container on Azure
Global Azure Bootcamp Québec - Container on AzureJulien Maitrehenry
 
Build a Docker Swarm cluster on Azure
Build a Docker Swarm cluster on Azure Build a Docker Swarm cluster on Azure
Build a Docker Swarm cluster on Azure Julien Maitrehenry
 
Retour d'expérience sur notre stack de log
Retour d'expérience sur notre stack de logRetour d'expérience sur notre stack de log
Retour d'expérience sur notre stack de logJulien Maitrehenry
 
Docker, ça mange quoi au printemps
Docker, ça mange quoi au printempsDocker, ça mange quoi au printemps
Docker, ça mange quoi au printempsJulien Maitrehenry
 
Sécuriser Docker - Utilisation du CIS Docker 1.12 by @guytalbot
Sécuriser Docker - Utilisation du CIS Docker 1.12 by @guytalbotSécuriser Docker - Utilisation du CIS Docker 1.12 by @guytalbot
Sécuriser Docker - Utilisation du CIS Docker 1.12 by @guytalbotJulien Maitrehenry
 
Fullstack monitoring - Overview
Fullstack monitoring - OverviewFullstack monitoring - Overview
Fullstack monitoring - OverviewJulien Maitrehenry
 
Docker cluster with swarm, consul, registrator and consul-template
Docker cluster with swarm, consul, registrator and consul-templateDocker cluster with swarm, consul, registrator and consul-template
Docker cluster with swarm, consul, registrator and consul-templateJulien Maitrehenry
 

Plus de Julien Maitrehenry (11)

Comment maitriser git et produire de beaux commits
Comment maitriser git et produire de beaux commitsComment maitriser git et produire de beaux commits
Comment maitriser git et produire de beaux commits
 
Docker, but what it is?
Docker, but what it is?Docker, but what it is?
Docker, but what it is?
 
Global Azure Bootcamp Québec - Container on Azure
Global Azure Bootcamp Québec - Container on AzureGlobal Azure Bootcamp Québec - Container on Azure
Global Azure Bootcamp Québec - Container on Azure
 
Build a Docker Swarm cluster on Azure
Build a Docker Swarm cluster on Azure Build a Docker Swarm cluster on Azure
Build a Docker Swarm cluster on Azure
 
Retour d'expérience sur notre stack de log
Retour d'expérience sur notre stack de logRetour d'expérience sur notre stack de log
Retour d'expérience sur notre stack de log
 
Docker, ça mange quoi au printemps
Docker, ça mange quoi au printempsDocker, ça mange quoi au printemps
Docker, ça mange quoi au printemps
 
Code, ship and run
Code, ship and runCode, ship and run
Code, ship and run
 
Sécuriser Docker - Utilisation du CIS Docker 1.12 by @guytalbot
Sécuriser Docker - Utilisation du CIS Docker 1.12 by @guytalbotSécuriser Docker - Utilisation du CIS Docker 1.12 by @guytalbot
Sécuriser Docker - Utilisation du CIS Docker 1.12 by @guytalbot
 
Docker introduction
Docker introductionDocker introduction
Docker introduction
 
Fullstack monitoring - Overview
Fullstack monitoring - OverviewFullstack monitoring - Overview
Fullstack monitoring - Overview
 
Docker cluster with swarm, consul, registrator and consul-template
Docker cluster with swarm, consul, registrator and consul-templateDocker cluster with swarm, consul, registrator and consul-template
Docker cluster with swarm, consul, registrator and consul-template
 

Docker, mais qu’est-ce que c’est ?

  • 1. Docker, mais qu’est-ce que c’est ? Introduction à Docker et son écosystème
  • 2. Qui suis-je ? Julien Maitrehenry DevOps, Cloud Architect, Développeur Co-fondateur @Kumojin Kumojin.com Github.com/jmaitrehenry jmaitrehenry.ca
  • 3. Agenda • Qu’est-ce que Docker ? • Docker Compose • Orchestration • Docker Desktop • Questions ? Photo by Ian Taylor on Unsplash
  • 5. Mais que signifie « Docker » ? • Le projet d’une communauté Open Source • Les outils issus de ce projet • L’entreprise Docker inc.
  • 7. Au commencement • Un seul but • Communauté des développeurs sous linux seulement • Un gros binaire
  • 8. Et maintenant ? • Linux et Windows • Multi Architecture (intel, armv5-8, ppc, i386) • Docker utilise plusieurs composants séparés • Standardisation des composants (OCI, CNCF) • Adopté par une large majorité des clouds
  • 9. Qu’est-ce qu’un conteneur ? • Un espace isolé où s’exécute une application • L’espace isolé contient toutes les libs pour rouler son application • Possède sa propre stack réseau, ses users, ses processus • Partage le kernel de l’hôte • Peut avoir des restrictions sur l’utilisation des ressources (CPU, Ram, etc)
  • 10. En quoi c’est différent d’une VM ?
  • 12. Qu’est-ce qu’une image? • Un ensemble de couche • Chaque couche est immutable • Chaque couche est réutilisable
  • 13. Construisons une image docker Image de base Variable d’environnement Variable définie lors du build Dossier de travail – alias dossier courant Copie de fichiers dans l’image Commande executée lors du build Copie du dossier dans l’image Commande par défaut qui sera executée lors d’un docker run
  • 14. Comment transformer notre fichier en image ? ❯ docker build -t myapp:v1.0.0 --build-arg NODE_ENV=development . Commande pour construire une image Donner un nom et un tag à l’image Passer une variable de build Contexte du build Si le fichier Dockerfile porte un autre nom ou est situé ailleurs, il faut le spécifier avec : -f .docker/Dockerfile Attention : le contexte de build est toujours le dernier paramètre
  • 15. Comment lancer un conteneur ? - Je ne peux pas accéder à l’app depuis mon navigateur - Ctr+C n’arrête pas l’app - Le nom du conteneur va être généré aléatoirement (ex: goofy_kapitsa) ❯ docker run myapp:v1.0.0 Commande pour exécuter un container Nom de l’image et son tag
  • 16. Comment lancer un conteneur ? ❯ docker run –ti -p 8080:80 --name myapp myapp:v1.0.0 Exécute en mode intéractif et avec un tty Lie le port 80 du container au port 8080 du host Donne le nom myapp au container
  • 17. Comment lancer un conteneur ? ❯ docker run –d -p 8080:80 --name myapp myapp:v1.0.0 Lance le container en arrière plan ❯ docker run –ti –p 8080:80 --name myapp --rm myapp:v1.0.0 bash Supprime automatiquement le conteneur quand il sera arrêté Change la commande par défaut (CMD)
  • 18. Recap
  • 19. Docker Engine • Application Client-Server pour: • Gérer des images • Gérer des conteneurs • Gérer des réseaux • Gérer des volumes • Possède une API REST et un CLI
  • 20. Volume • Conserver des données en dehors du conteneur • Partager des données avec l’hôte • D’autres drivers possibles This Photo by Unknown Author is licensed under CC BY-SA-NC
  • 21. Partager un dossier/fichier entre le host et le conteneur ❯ docker run -ti --rm -v `pwd`/mydir:/data ubuntu Instruction pour utiliser un volume Dossier local sur l’host Dossier dans le conteneur Attention dans le cas où l’on monte un fichier ! Les modifications au fichier peuvent ne pas être reflétées dans le conteneur Ex: sed, vim, etc
  • 22. Utilisation d’un volume ❯ docker volume create mydata ❯ docker run -ti --rm -v mydata:/data ubuntu Sous commande pour gérer les volumes Nom du volume Nom du volume au lieu du path local
  • 23. Network • Permet de créer des réseaux isolés • Les conteneurs peuvent communiquer entre eux par nom de container, id ou alias • Plusieurs drivers disponibles : • Bridge (default) • Internal • None • Host
  • 24. Internal network ❯ docker network create --internal intnet ❯ docker run --network intnet curlimages/curl -m3 https://google.com ╰─❯ curl: (28) Resolving timed out after 3002 milliseconds Sous commande pour gérer les réseaux Type de réseau Nom du réseau Attache le conteneur au réseau intnet
  • 25. Communication intra conteneur ❯ docker network create --driver bridge mynet ❯ docker run -d --network mynet --name nginx --network-alias web nginx ❯ docker run --rm --network mynet curlimages/curl -m3 http://web Utilise un driver réseau sécifique Ajoute un alias au conteneur dans les réseaux où il est connecté Le nom et l’ID du conteneur fonctionne aussi
  • 26. Autres réseaux utiles ❯ docker run --rm --network none curl -m3 https://google.com ❯ docker run –d --network host nginx Sans isolation réseau entre le conteneur et l’hôte Sans réseau
  • 28. Construisons un fichier docker compose Version du format du fichier Définition des services, alias des conteneurs Définition des réseaux Définition des volumes
  • 29. Construisons un fichier docker compose Nom du service ainsi que de son nom sur les réseaux Image docker du conteneur Si le containeur crash, docker le relance Liste des volumes à attacher au conteneur Liste des variables d’environnement Liste des réseaux à attacher au conteneur
  • 30. Construisons un fichier docker compose Surcharge de la commande par défaut de l’image On peut attacher un volume dans un dossier d’un autre volume Définition pour construire l’image Docker Créer une dépendance à un autre service Liste des ports à lier sur le host
  • 31. Construisons un fichier docker compose Sur un réseau séparé de la base de données
  • 32. Comment utiliser un un fichier compose ? ❯ docker compose ps -a Liste les conteneurs créer par compose Incluant ceux arrêtés ❯ docker compose logs -f [nom du/des service(s)] Affiche les logs Et affiche les nouveaux messages au fur et à mesure ❯ docker compose up –d [nom du/des service(s)] Sous commande pour gérer compose Lance un/des services/tous les services En background
  • 33. Registry Docker • Héberge les images Docker • Nombreux Registry en ligne disponibles: • Docker Hub • Azure ACR • AWS ECR • Github Registry • … • Nombreuses solutions self-hosted: • Docker Registry • Nexus • Artifactory • …
  • 34. Commandes utiles ❯ docker login / docker login kumojin.azurecr.io Connecte Docker à un registry Télécharge une image dans un registry Pousse une image du registry localement ❯ docker push jmaitrehenry/myimage ❯ docker pull kumojin.azurecr.io/myapp/api:v1.0.0 Se connecte à un registry spécifique
  • 35. Orchestration • Pourquoi faire ? • Outils d’orchestration • Solutions cloud
  • 36. Pour quoi faire ? • Approvisionnement et placement des containeurs • Mécanisme de healthcheck et métriques • Gestion des indisponibilités et scalabilité • Gestion des déploiements • Service discovery et gestion du réseau • Et plus encore !
  • 38. Solutions Cloud • Basé sur Kubernetes • Azure: AKS • AWS: EKS • Google: GKE • Basée sur des conteneurs • Azure ACI • AWS Fargate • AWS ECS
  • 39. Docker Desktop Qu’est-ce que c’est ? Qu’est-ce que cela apporte ?