Présentation

Historique

  • Créé par Solomon Hykes (français)
  • Idée est venu de l'industrie du transport
  • Première version en mars 2013

Principe

Principe

Avantages

  • Configuration simplifiée

  • Environnement consistant

  • Application facilement isolée

  • Déploiement rapide

  • Virualisation plus légère

Inconvénients

  • Basé sur du Linux

  • Complexité supplémentaire

  • Outils de monitoring et management

  • Sécurité des images publiques

Conteneur VS VM

Sur les différents OS

Linux

Windows

Mac

Image

Présentation

Présentation

Dockerfile

Dockerfile

Dockerfile

Gestion globale

Lister les images

$ docker images
REPOSITORY                        TAG                 IMAGE ID            CREATED           SIZE
gitlab/gitlab-ce                  latest              123dce7befbc        4 days ago        1.216 GB
aquasys/java                      latest              8296b08b5566        5 days ago        640.9 MB
lolhens/artifactory               latest              8f7705ed061d        2 weeks ago       504 MB
java                              8                   96cddf5ae9f1        2 weeks ago       640.9 MB
aquasys/sbt                       latest              bf9d748f4603        3 months ago      176.7 MB
rabbitmq                          latest              7d35f955ee99        4 months ago      177.8 MB
1science/sbt                      latest              244262a4d9ad        4 months ago      176.7 MB
hseeberger/scala-sbt              latest              3cd03e0fbc45        4 months ago      770.3 MB
postgres                          9.4                 fad840dae449        7 months ago      263.1 MB

Construire une image

$ docker build -t aquasys/sbt .
Sending build context to Docker daemon 61.44 kB
Step 1 : FROM 1science/sbt
 ---> 244262a4d9ad
Step 2 : EXPOSE 9000
 ---> Running in 3e8db64a4788
 ---> 42db24e06919
Removing intermediate container 3e8db64a4788
Step 3 : EXPOSE 9999
 ---> Running in 4a24f1a499ab
 ---> 3871c32cc872
Removing intermediate container 4a24f1a499ab
Step 4 : WORKDIR /app
 ---> Running in c1a12b9f4c13
 ---> 1e8abfdb5e22
Removing intermediate container c1a12b9f4c13
Step 5 : CMD sbt -jvm-debug 9999 run
 ---> Running in b5ed1a3873dd
 ---> 983192e06946
Removing intermediate container b5ed1a3873dd
Successfully built 983192e06946

Supprimer une image

docker rmi aquasys/sbt
Untagged: aquasys/sbt:latest
Deleted: sha256:983192e06946a1aafe93b013ab384eab75de204ba96d568ff2897b4105f351ba
Deleted: sha256:1e8abfdb5e22e978c2c0cfd6267d97a8b5e7208a34b8e7c9831f5cde6ddac7b7
Deleted: sha256:3871c32cc872c2acf1f9723df41933a3e46676e3224980e7b60902f85e490a22
Deleted: sha256:42db24e06919cb95937dbfbfb76076bd9fc2bd109c9d81f187b431492c138542

Docker Hub

Rechercher une image

$ docker search sinatra
NAME                                   DESCRIPTION              STARS     OFFICIAL   AUTOMATED
training/sinatra                       Sinatra training image   0                    [OK]
marceldegraaf/sinatra                  Sinatra test app         0
mattwarren/docker-sinatra-demo                                  0                    [OK]
luisbebop/docker-sinatra-hello-world                            0                    [OK]
subwiz/sinatra                                                  0
bmorearty/sinatra                                               0

Récupérer une image

$ docker pull centos

Using default tag: latest
latest: Pulling from library/centos
f1b10cd84249: Pull complete
c852f6d61e65: Pull complete
7322fbe74aa5: Pull complete
Digest: sha256:90305c9112250c7e3746425477f1c4ef112b03b4abe78c612e092037bfecc3b7
Status: Downloaded newer image for centos:latest

Partager une image

$ docker push ouruser/sinatra

The push refers to a repository [ouruser/sinatra] (len: 1)
Sending image list
Pushing repository ouruser/sinatra (3 tags)

Conteneur

Présentation

Présentation

One process per container

Gestion globale

Liste des conteneurs

$ docker ps -a
CONTAINER ID    IMAGE                    COMMAND                CREATED        STATUS                    
PORTS                                                            NAMES
2179702eb174    gitlab/gitlab-ce:latest  "/assets/wrapper"      4 minutes ago  Up 4 minutes
0.0.0.0:22->22/tcp, 0.0.0.0:443->443/tcp, 0.0.0.0:9000->80/tcp   gitlab
1f8dfad56928    rabbitmq                 "/docker-entrypoint.s" 3 months ago   Exited (0) 5 days ago     
4369/tcp, 5671-5672/tcp, 25672/tcp                               some-rabbit

Lancement d'un conteneur

$ docker run --detach \
    --hostname gitlab.example.com \
    --publish 443:443 --publish 80:80 --publish 22:22 \
    --name gitlab \
    --restart always \
    --volume /srv/gitlab/config:/etc/gitlab \
    --volume /srv/gitlab/logs:/var/log/gitlab \
    --volume /srv/gitlab/data:/var/opt/gitlab \
    gitlab/gitlab-ce:latest

2179702eb174343b59c1aa9bf2260e34db0ab4ceb64cdf395fbaee28ab358a07

Lancement d'un conteneur - detach

$ docker run --help
...
...
...
-d, --detach                      Run container in background and print container ID

Lancement d'un conteneur - publish

$ docker run --help
...
...
...
-p, --publish value               Publish a container's port(s) to the host (default [])

Lancement d'un conteneur - restart

no Do not automatically restart the container when it exits. This is the default.
on-failure[:max-retries] Restart only if the container exits with a non-zero exit status. Optionally, limit the number of restart retries the Docker daemon attempts.
Policy Result

Lancement d'un conteneur - restart

always Always restart the container regardless of the exit status. When you specify always, the Docker daemon will try to restart the container indefinitely.
unless-stopped Always restart the container regardless of the exit status, but do not start it on daemon startup if the container has been put to a stopped state before.
Policy Result

Accès aux logs

$ docker logs 2179702eb174343b59c1aa9bf2260e34db0ab4ceb64cdf395fbaee28ab358a07
$ docker logs 21797
$ docker logs -f 21797
$ docker logs --help

Usage:	docker logs [OPTIONS] CONTAINER

Fetch the logs of a container

Options:
      --details        Show extra details provided to logs
  -f, --follow         Follow log output
      --help           Print usage
      --since string   Show logs since timestamp
      --tail string    Number of lines to show from the end of the logs (default "all")
  -t, --timestamps     Show timestamps

Redémarrage

$ docker stop gitlab
$ docker start 21797
$ docker restart 21797

Suppression

$ docker rm gitlab
gitlab

Attachement au conteneur

$ docker attach topdemo
top - 02:05:52 up  3:05,  0 users,  load average: 0.01, 0.02, 0.05
Tasks:   1 total,   1 running,   0 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.1%us,  0.2%sy,  0.0%ni, 99.7%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:    373572k total,   355560k used,    18012k free,    27872k buffers
Swap:   786428k total,        0k used,   786428k free,   221740k cached

PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
 1 root      20   0 17200 1116  912 R    0  0.3   0:00.03 top

 top - 02:05:55 up  3:05,  0 users,  load average: 0.01, 0.02, 0.05
 Tasks:   1 total,   1 running,   0 sleeping,   0 stopped,   0 zombie
 Cpu(s):  0.0%us,  0.2%sy,  0.0%ni, 99.8%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
 Mem:    373572k total,   355244k used,    18328k free,    27872k buffers
 Swap:   786428k total,        0k used,   786428k free,   221776k cached

   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
       1 root      20   0 17208 1144  932 R    0  0.3   0:00.03 top


 top - 02:05:58 up  3:06,  0 users,  load average: 0.01, 0.02, 0.05
 Tasks:   1 total,   1 running,   0 sleeping,   0 stopped,   0 zombie
 Cpu(s):  0.2%us,  0.3%sy,  0.0%ni, 99.5%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
 Mem:    373572k total,   355780k used,    17792k free,    27880k buffers
 Swap:   786428k total,        0k used,   786428k free,   221776k cached

Attachement au conteneur

$ docker exec -i -t gitlab /bin/bash
root@cccb4ef3c19b:/# ls
RELEASE  bin   dev  home  lib64  mnt  proc  run   srv  tmp  var
assets   boot  etc  lib   media  opt  root  sbin  sys  usr
root@cccb4ef3c19b:/# exit
exit

$

Volumes

Persistance des données 

Affecter un volume

$ docker run -d -P --name web -v /src/webapp:/opt/webapp training/webapp python app.py
$ docker run -d -P --name web -v /src/webapp:/opt/webapp:ro training/webapp python app.py
$ docker run -d -P --name web -v /src/webapp:/opt/webapp:w training/webapp python app.py
FROM ubuntu
RUN mkdir /myvol
RUN echo "hello world" > /myvol/greeting
VOLUME /myvol

Partager un volume

$ docker create -v /dbdata --name dbstore training/postgres /bin/true
$ docker run -d --volumes-from dbstore --name db1 training/postgres
$ docker run -d --name db3 --volumes-from db1 training/postgres

Backup, restauration

$ docker run --rm --volumes-from dbstore -v $(pwd):/backup ubuntu tar cvf /backup/backup.tar /dbdata
$ docker run -v /dbdata --name dbstore2 ubuntu /bin/bash
$ docker run --rm --volumes-from dbstore2 -v $(pwd):/backup ubuntu bash \
-c "cd /dbdata && tar xvf /backup/backup.tar --strip 1"

Docker Compose

Présentation

Syntaxe

 version: '2'
 services:
   web:
     build: .
     ports:
      - "5000:5000"
     volumes:
      - .:/code
     depends_on:
      - redis
   redis:
     image: redis
FROM python:2.7
ADD . /code
WORKDIR /code
RUN pip install -r requirements.txt
CMD python app.py

Variables d'environnement

environment:
  RACK_ENV: development
  SHOW: 'true'
  SESSION_SECRET:

environment:
  - RACK_ENV=development
  - SHOW=true
  - SESSION_SECRET
env_file: .env

env_file:
  - ./common.env
  - ./apps/web.env
  - /opt/secrets.env

Docker Swarm

Présentation

En environnement de développement

Avantages

  • Utile pour du micro-service

  • Compilation à la volée

  • Environnement quasi-similaire (dev / prod)

Inconvénients

  • Mise en place

  • Différents OS

  • Formation

Mise en place

Monitoring

Logs

Métriques

docker stats

Health Check

docker

By benjamin tourman

docker

  • 703