This commit is contained in:
nemunaire 2015-10-22 05:25:20 +02:00 committed by Pierre-Olivier Mercier
commit d3281c2d51
10 changed files with 647 additions and 398 deletions

View file

@ -2,9 +2,7 @@
# Installation
## Docker
### Par le gestionnaire de paquets
## Par le gestionnaire de paquets
Sous Debian et ses dérivés (Ubuntu, Mint, ...) le paquet et la commande ont été
nommés `docker.io`. Vous pouvez vous créer un alias `alias docker=docker.io` si
@ -13,7 +11,44 @@ celui-ci n'a pas déjà été défini.
Sous les autres distributions, `docker` correspond a priori bien à la solution
de virtualisation légère que l'on va utiliser.
### Manuellement
### Debian Jessie
`docker` se trouve dans les backports, ajouter-les à votre `/etc/apt/sources.list` :
```
deb http://ftp.debian.org/debian/ wheezy-backports main non-free contrib
```
Puis :
```
apt-get update
apt-get install docker.io
```
### Debian Wheezy
Il vous faut utiliser le dépôt de paquets fourni par Docker :
```
apt-key adv --keyserver hkp://pgp.mit.edu:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D
```
Ajoutez cette ligne dans votre `/etc/apt/sources.list` :
```
deb https://apt.dockerproject.org/repo debian-wheezy main
```
Puis :
```
apt-get update
apt-get install docker-engine
```
## Manuellement
L'équipe en charge de Docker met à disposition un script pour installer Docker
sur n'importe quel système :
@ -22,7 +57,8 @@ sur n'importe quel système :
curl -sSL https://get.docker.com/ | sh
```
### Vérifier la bonne marche de l'installation
## Vérifier la bonne marche de l'installation
Vous devriez maintenant être capable de lancer la commande suivante :
@ -33,17 +69,29 @@ docker version
Une sortie similaire au bloc suivant devrait apparaître sur votre écran :
```
Client version: 1.3.2
Client version: 1.3.3
Client API version: 1.15
Go version (client): go1.3.3
Git commit (client): 39fa2fa
Git commit (client): d344625
OS/Arch (client): linux/amd64
Server version: 1.3.2
Server version: 1.3.3
Server API version: 1.15
Go version (server): go1.3.3
Git commit (server): 39fa2fa
Git commit (server): d344625
```
### `no such file or directory`?
Si vous avez cette erreur : `dial unix /var/run/docker.sock: no such file or
directory.`, le deamon n'est sans doute pas lancé. Lancez-le :
```
sudo service docker restart
```
### `permission denied`?
Si vous avez cette erreur : `dial unix /var/run/docker.sock: permission
denied.`, ajoutez votre utilisateur au groupe `docker` et **relancer votre
session** :
@ -51,3 +99,21 @@ session** :
```
sudo gpasswd -a $USER docker
```
**Attention :** cette action n'est pas anodine d'un point de vue sécurité :
<https://docs.docker.com/articles/security/#docker-daemon-attack-surface>
## Rendu
### Questions
1. Dans quel langage Docker a-t-il été écrit ? Docker utilise la `libcontainer`
afin d'avoir une couche d'abstraction des *namespaces* et des
*cgroups*. Dois-je installer cette bibliothèque avant de recopier sur une
nouvelle machine le binaire `docker` (sans passer par le gestionnaire de
paquets) ? Pourquoi ?
1. Décrivez une méthode permettant à un utilisateur (non-root),
présent dans le groupe `docker`, d'effectuer une action
privilégiée impactant la machine hôte.