Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Dernière révisionLes deux révisions suivantes
enseignement:d35:tp:docker [2016/01/07 14:38] Emmanuel Brunoenseignement:d35:tp:docker [2018/11/09 10:23] Emmanuel Bruno
Ligne 1: Ligne 1:
-====== D35 - TP5 - Docker ====== 
-===== Installer docker et docker-machine ===== 
  
-Vous pouvez installer Docker sur votre machine personnelle en suivant : https://docs.docker.com/engine/installation/. 
- 
-Nous allons commencer par le mettre en place sur les machines des salles de TP (donc sans être root) cela fonctionne bien mais avec certaines limites (sur les volumes notamment). 
- 
-<note warning> 
-Pour que la machine virtuelle fonctionne, la machine hôte doit disposer d'un processeur compatible. Vous pouvez le tester avec (cette commandes doit renvoyer un résultat) : 
-  grep --color -e vmx -e svm /proc/cpuinfo 
-</note> 
- 
-Penser à configurer le proxy dans l'hôte : 
-<cli> 
-export https_proxy=http://login:password@proxy.univ-tln.fr:3128/ && export http_proxy=$https_proxy  
-</cli> 
- 
-Télécharger et installer les binaires de docker engine (c'est le moteur mais nous n'utiliserons que le client sur l'hôte) et docker machine (le gestionnaire de VM). 
-<cli> 
-export PATH=~/bin:${PATH} 
-cd ~/bin 
-curl -L https://get.docker.com/builds/Linux/x86_64/docker-latest > docker && chmod +x docker 
-curl -L https://github.com/docker/machine/releases/download/v0.5.3/docker-machine_linux-amd64 > docker-machine && chmod +x docker-machine 
-curl -L https://github.com/docker/compose/releases/download/1.5.2/docker-compose-`uname -s`-`uname -m` > docker-compose && chmod +x docker-compose 
-</cli> 
- 
-Créer une machine virtuelle en y installant docker engine, fixer les variables d'environnement qui vont permettre au client docker exécuter sur l'hôte d'utiliser le moteur installé dans la VM : 
-<cli> 
-docker-machine create --driver virtualbox default 
-eval "$(docker-machine env --no-proxy default)" 
-docker-machine ip default 
-</cli> 
- 
-<note warning> 
-Attention, par défaut la machine virtuelle est créée dans le répertoire  
-~/docker/machine. En salle de TP celui-ci est sur le réseau, vous pouvez créer le répertoire ''votrelogin'' dans ''/usr/local/vbox/travail/'' et ajouter l'option ''--storage-path "/usr/local/vbox/travail/votrelogin"'' pour utiliser un espace local sur l'hôte.</note> 
- 
-La suite est maintenant inutile grâce à l'ajout de l'option --no-proxy dans la commande eval précédente.  
-<del>Supprimer le proxy dans l'hôte: 
-<cli> 
-unset http_proxy  && unset https_proxy 
-</cli></del> 
- 
-Se connecter dans la VM et ajouter le proxy web pour permettre le téléchargement des images : 
-<cli> 
-docker-machine -D ssh default 
-sudo vi /var/lib/boot2docker/profile 
-</cli> 
- 
-ajouter dans le fichier : 
-   
-  export HTTP_PROXY=http://login:password@proxy.univ-tln.fr:3128 
-  export HTTPS_PROXY=http://login:password@proxy.univ-tln.fr:3128 
-  export NO_PROXY=localhost,127.0.0.0/8,docker.lsis.univ-tln.fr 
- 
-puis relancer le service docker dans boot2docker (la VM), quitter la VM et tester depuis l'hôte: 
-<cli> 
-sudo /etc/init.d/docker restart 
-exit 
-docker search ubuntu 
-docker pull debian 
-docker run -it --name debian debian 
-</cli> 
- 
-<note> 
-Supprimer le conteneur Debian, ainsi que l'image.  
- 
-Attention, la place est limitée dans la VM (cf. --virtualbox-disk-size à la création de la VM avec docker-machine) et surtout sur votre compte. 
- 
-Le paramétrage du proxy peut être fait dès la création de la VM :  
-docker-machine create --driver virtualbox --engine-env http_proxy=http://login:passwd@proxy.univ-tln.fr:3128/ --engine-env https_proxy=http://login:passwd@proxy.univ-tln.fr:3128/ default 
-</note> 
- 
-==== Découverte de Docker ==== 
-<note> 
-Suivre le tutoriel https://docs.docker.com/linux/ pour créer sa propre image. 
-</note> 
- 
-Il est possible de passer des variables d'environnement lors de la construction de l'image sans que celles-ci n'y soient stockées (c'est utilise pour le proxy par exemple) : ''--build-arg HTTP_PROXY=http://...'' 
- 
-Vous pouvez maintenant construire vos propres images, en personnalisant d'autres (java, maven, payara, mysql, ...). Pour orchestrer l'installation d'un environnement complet composé de plusieurs conteneur il faut étudier : https://docs.docker.com/compose/ 
- 
-==== Accéder à ses fichiers depuis les conteneurs ==== 
- 
-Cette partie est optionnelle dans un premier temps.  
- 
-Depuis l'hôte, créer un répertoire qui sera exporté vers la VM et les conteneurs et ajouter le partage à VirtualBox 
-<cli> 
-bruno@u0251:~$ mkdir DOCKER 
-bruno@u0251:~$ docker-machine stop default 
-bruno@u0251:~$ VBoxManage sharedfolder add default --name dockerhome --hostpath /home/perso/bruno/DOCKER 
-bruno@u0251:~$ docker-machine start default 
-bruno@u0251:~$ eval "$(docker-machine env --no-proxy default)" 
-</cli> 
- 
-Dans la VM, monter le partage  
-<cli> 
-bruno@u0251:~$ docker-machine -D ssh default 
-docker@default:~$ mkdir HOME 
-docker@default:~$ sudo mount -t vboxsf dockerhome HOME 
-</cli> 
- 
-Maitenant vous pouvez créer des fichiers dans le "même" répertoire sur l'hôte (''/home/perso/bruno/DOCKER'') et dans la VM (ici ''/docker/HOME). Le répertoire /docker/HOME peut maintenant être utilisé comme premier paramètre de ''run -v ...'' pour utiliser des fichiers de l'hôte dans les conteneurs. Il faut faire attention aux droits par défaut (root). 
- 
-==== Travail à faire ==== 
-  * Mettre en place plusieurs serveurs MYSQL sur votre machine chacun doit pouvoir être utilisé par le client sur l'hôte. 
-    * Modifier le pour que les base de données soit dans des conteneurs séparés (si vous êtes root vous pouvez aussi monter un répertoire local). 
-  * Créer un conteneur qui contient et exécute une application peut exécuter une application Java. 
-  * En utilisant docker-compose, créer des conteneurs qui permette en une seule commande de lancer une base de données et une application java qui s'y connecte. 
-  * Compiler une application Java avec Maven en utilisant docker. Si vous n'êtes pas root et ne pouvez pas monter les volumes de l'hôtes, un indice cherchez avec ONBUILD.  
- 
-==== Cas d'usage avec GitLab ==== 
-<note> 
-Après avoir eu un compte sur https://gitlab.lsis.univ-tln.fr/, créer un projet, y déposer le projet de base créé par l'archetype maven quickstart et mettre en place l'intégration continue en suivant les instructions suivantes.  
-</note> 
- 
-Ajouter simplement le fichier minimal suivant à la racine (Il indique l'image à utiliser et la commande). 
- 
-<file | .gitlab-ci.yml> 
-package: 
-  image:  docker.lsis.univ-tln.fr:443/ebruno/maven:latest 
-  script: mvn package 
-</file> 
- 
-Vérifier que la compilation et les tests passent, vérifier qu'une erreur est bien détecté. Par défaut, gitlab utilise des runner (https://gitlab.com/gitlab-org/gitlab-ci-multi-runner) partagé qui ont été configurés pour utiliser docker, vous pouvez installer des runners spécifiques sur n'importe quelle machine pour vos projets.  
- 
-==== Utilisation d'un repository privé pour la compilation ==== 
-Se connecter au repository privé (il faut un compte à demander à M. Bruno) et installer l'image Maven dans la VM : 
-<cli> 
-docker login docker.lsis.univ-tln.fr:443 
-docker pull docker.lsis.univ-tln.fr:443/ebruno/maven:latest 
-</cli> 
- 
-Un simple test de maven : 
-<cli> 
-docker run -v `pwd`:/usr/src/app -v ~/.m2:/home/user/.m2 -u `id -u`:`id -g` docker.lsis.univ-tln.fr:443/ebruno/maven:latest mvn -Duser.home=/home/user -version 
-</cli> 
- 
-Une compilation complète (ne marche pas en non root ou dans le groupe docker à cause du montage NFS) : 
- 
-<cli> 
-mvn archetype:generate \ 
- -DarchetypeGroupId=org.apache.maven.archetypes \ 
- -DarchetypeArtifactId=maven-archetype-quickstart \ 
- -DarchetypeVersion=1.1 \ 
- -DgroupId=fr.univtln.login \ 
- -DartifactId=MyApp \ 
- -Dversion=1.0-SNAPSHOT 
- 
-cd MyApp 
- 
-docker run -v `pwd`:/usr/src/app -v ~/.m2:/home/user/.m2 -u `id -u`:`id -g` docker.lsis.univ-tln.fr:443/ebruno/maven:latest mvn -Duser.home=/home/user package 
-</cli> 
-Le répertoire courant est monté dans le conteneur dans la VM, ainsi que le ~/.m2 
- 
-{{tag>D35 TP Docker }} 
- 
----- dataentry page ---- 
-type                 : TP 
-enseignement_tags    : D35 
-technologie_tags     : Docker 
-theme_tags           : Composants 
-----  
 ---- struct data ---- ---- struct data ----
 +metadata.level       : 
 +metadata.Type        : TP
 +metadata.Nom         : 
 +metadata.Enseignements : D35
 +metadata.Promotions  : M2
 +metadata.Technologies : Docker
 +metadata.Thèmes     : devops
 +metadata.Description : 
 ---- ----