Académique Documents
Professionnel Documents
Culture Documents
Apprendre Kubernetes
et créer son propre
labo expérimental
E-handbook
Dans ce guide
Introduction.
Comment créer son cluster
Kubernetes est incontestablement devenu le standard en matière de
Kubernetes en local avec
Minikube déploiement d’applications Cloud-natives. Un composant clé que
doivent maîtriser tous les opérationnels et les développeurs. Inscrire
Comment bien se former à Kubernetes parmi ses compétences créera sur un CV un vrai
Kubernetes distinguo. Reste donc à apprendre. Et sur ce point, la courbe
d’apprentissage de cet orchestrateur de containers est bien abrupte.
Comment utiliser Github dans
son labo DevOps
Ce guide vous accompagnera dans la mise en place de votre propre
labo Kubernetes afin que vous puissiez tester vos connaissances et
Git : 5 commandes basiques
que l’on doit maîtriser
accélérer votre maîtrise de cette nouvelle technologie
Page 1 of 45
E-handbook
Page 2 of 45
E-handbook
Dans ce guide
Comment créer son cluster Kubernetes en
Comment créer son cluster local avec Minikube
Kubernetes en local avec
Minikube Alastair Cooke, Consultant
Git : 5 commandes basiques Kubernetes est devenu la brique logicielle standard si l’on souhaite entrer dans
que l’on doit maîtriser le monde des containers et des architectures de microservices. Le hic : sa
courbe d’apprentissage peut souvent rebuter les moins aguerris. Ces
Démarrer avec Ansible pour professionnels ont dès lors besoin de se familiariser avec la belle mécanique de
configurer son labo DevOps Kubernetes et de développer leurs compétences à leur rythme. Une des
solutions : monter son propre Kubernetes et apprendre.
Page 3 of 45
E-handbook
Comment créer son cluster Cet article vous guide pas à pas dans l’installation de vitre labo, vous aide à
Kubernetes en local avec exécuter les commandes kubectl, et vous transporte au plus près des
Minikube workloads dans K8.
Démarrer avec Ansible pour Les lignes de commande Minikube kubectl s'exécutent directement sur
configurer son labo DevOps l'ordinateur d'origine, et les applications motorisées par Kubernetes y sont
également accessibles.
Page 4 of 45
E-handbook
Comment créer son cluster Pour démarrer ce tutoriel, installez la dernière version de VirtualBox, puis
Kubernetes en local avec installez la ligne de commande kubectl pour gérer Kubernetes, par
Minikube téléchargement direct. Minikube est également installé par téléchargement
direct.
Comment bien se former à
Kubernetes
Page 5 of 45
E-handbook
Une fois téléchargé, Minikube n'a pas besoin d'un accès Internet - à condition
Dans ce guide que toutes les images Docker nécessaires aient déjà été téléchargées.
A ce stade du tutoriel, vous avez tout ce dont vous avez besoin pour
commencer à apprendre Kubernetes. Démarrez deux instances du serveur web
Nginx, puis vérifiez que les deux instances sont disponibles.
Page 6 of 45
E-handbook
Dans ce guide
Page 7 of 45
E-handbook
Nginx s’exécute dans deux conteneurs Docker mais n'est pas accessible hors
Dans ce guide du cluster Kubernetes. La façon la plus simple d'exposer le déploiement et de le
rendre accessible de l'extérieur est d'utiliser l'adresse IP standard
Comment créer son cluster 192.168.99.100 (de la Minikube VM) et d'exposer un NodePort. Le système
Kubernetes en local avec
convertit l'adresse pour le port TCP de cette adresse IP vers l'adresse IP
Minikube
interne du conteneur.
Figure 4. Expose un NodePort pour permettre à Nginx d’accéder depuis l’extérieur au cluster
Git : 5 commandes basiques Kubernetes.
que l’on doit maîtriser
Pour s'assurer que Nginx est actif, ouvrez un navigateur Web, et
Démarrer avec Ansible pour entrez http://192.168.99.100:<port>, où le port est celui indiqué dans
configurer son labo DevOps la commande kubectl get services, comme le montre la Figure 4 ci-
dessus.
Un serveur web est maintenant déployé sur Kubernetes.
Jusqu'à présent, nous avons utilisé des outils en ligne de commande pour gérer
Kubernetes, ce qui est une excellente pratique pour l'automatisation.
Cependant, une interface graphique facilite grandement l'exploration de ce qui
Page 8 of 45
E-handbook
Figure 5. Une interface graphique (GUI) permet aux utilisateurs d’explorer leur propre
laboratoire Kubernetes en dehors de la ligne de commande.
Page 9 of 45
E-handbook
Page 10 of 45
E-handbook
Page 11 of 45
E-handbook
Comment créer son cluster Pour commencer, installez Vagrant. Rendez-vous sur vagrantup.com, et
Kubernetes en local avec téléchargez le programme d'installation pour votre OS. Vagrant fonctionne avec
Minikube de nombreuses plateformes de virtualisation, mais ce didacticiel utilise Oracle
VM VirtualBox (gratuite et open source) car elle est facile à utiliser. Installez
Comment bien se former à donc la dernière version de VirtualBox.
Kubernetes
Ensuite, installez le dépôt Git. Ce labo Kubernetes est disponible dans les
Comment utiliser Github dans fichiers Git de l'auteur ce cet article.
son labo DevOps
Figure 1
Les outils Git s'installent automatiquement lorsque l’on exécute pour la première
fois une commande Git (voir Figure 1). Il existe une variété d'outils Git, comme
l'application officielle GitHub Desktop (pour Windows par exemple).
Page 12 of 45
E-handbook
Ce laboratoire a été créé sur Red Hat Fedora 25. Cet OS offre la possibilité
Dans ce guide d'utiliser la bonne version de Docker et permet un déploiement d'infrastructure
Kubernetes assez simple. Kubernetes a la réputation d'être un projet complexe.
Comment créer son cluster Vous pouvez alors partager du code sur un dépôt GitHub avec d'autres
Kubernetes en local avec
membres de la communauté opérationnelle de Kubernetes.
Minikube
Figure 2.
Page 13 of 45
E-handbook
Page 14 of 45
E-handbook
Dans ce guide
Figure 3.
Page 15 of 45
E-handbook
Le script master (voir Figure 4) est plus complexe que celui du worker, car il doit
Dans ce guide configurer le cluster Kubernetes et la machine virtuelle maître que
l'administrateur utilisera pour gérer le cluster. Le premier bloc de master.sh (en
Comment créer son cluster rouge) concerne l'installation de Docker, en particulier Docker version 17.03
Kubernetes en local avec
dans cet article. La ligne qui démarre sed -i change une ligne dans un fichier de
Minikube
configuration Docker afin que celui-ci utilise les pilotes que Kubernetes préfère.
Le deuxième bloc (en rose) installe Kubernetes et modifie à nouveau un fichier
Comment bien se former à de configuration par souci de cohérence. Le troisième bloc (en bleu) crée le
Kubernetes
cluster Kubernetes et le plug-in de mise en réseau qui permet aux connexions
réseau de fonctionner sur les nœuds. Les deux lignes du script de formation de
Comment utiliser Github dans cluster Kubernetes redirigent leur sortie dans un log. Il se situe dans /vagrant,
son labo DevOps
qui est un dossier à l'intérieur de la machine virtuelle. Il correspond au dossier
où se trouve le Vagrantfile. Figure 4.
Git : 5 commandes basiques
que l’on doit maîtriser
Page 16 of 45
E-handbook
Bien que l'installation nécessite un certain temps (voir Figure 5), il a fallu une
Dans ce guide demi-heure pour construire les VM et le cluster Kubernetes. Par exemple, le
téléchargement de l'image de Fedora 25 a pris beaucoup de temps, mais vous
Comment créer son cluster ne répéterez pas cette étape si vous recréez un labo identique sur ce même
Kubernetes en local avec
ordinateur.
Minikube
Page 17 of 45
E-handbook
Dans ce guide
Page 18 of 45
E-handbook
Vagrant ouvre une console pour le maître ; les deux nœuds restent headless,
Dans ce guide ce qui est la valeur par défaut de Vagrant. Utilisez ssh master vagrant pour
ouvrir une session sur le master, ou utilisez la fenêtre de la console. Pour
Comment créer son cluster observer le cluster, connectez-vous à la console de la machine virtuelle maître
Kubernetes en local avec
comme utilisateur vagrant avec vagrant pour mot de passe. Ensuite, lancez
Minikube
sudo kubectl get nodes : vous avez trois nœuds, un maître et deux avec
<none> comme rôle.
Comment bien se former à
Kubernetes
Ce didacticiel crée un cluster Kubernetes de base que l’on peut tester sans se
Démarrer avec Ansible pour
configurer son labo DevOps soucier de problème de production. Pour arrêter le laboratoire et libérer ses 4
Go de RAM, utilisez vagrant halt. Vous pouvez utiliser vagrant destroy pour
supprimer toutes les VM, puis vagrant up pour ré-initialiser. Pour que ces
commandes fonctionnent, elles doivent être saisies dans le répertoire où réside
le Vagrantfile.
Page 19 of 45
E-handbook
Comment utiliser Github dans Un déploiement DevOps nécessite une infrastructure qui peut être rapidement
son labo DevOps provisionnée pour s'adapter aux besoins des applications. Lorsque l’on crée son
environnement d’expérimentation DevOps avec Vagrant VM, ce dernier produit
Git : 5 commandes basiques
des fichiers contenant du code qui crée et décrit l'infrastructure du labo. Le
que l’on doit maîtriser logiciel de contrôle de version Git, ou toute autre outil - il est préférable d’en
choisir un adapté -, protège ce code et archive les anciennes versions lorsque
Démarrer avec Ansible pour
des modifications sont réalisées.
configurer son labo DevOps
Un commit Git sauvegarde un état cohérent - une copie séparée - du projet sur
la machine du labo DevOps. Il permet à l'utilisateur de revenir à un point fixe en
cas de modification du code. GitHub est d’une grande aide pour cela : il s’agit
d'une plateforme de contrôle de version distribuée, qui se comporte comme un
référentiel central pour le code.
Page 20 of 45
E-handbook
Comment créer son cluster Installez Git sur la machine de votre labo DevOps. L’installation est automatique
Kubernetes en local avec lorsque git s'exécute pour la première fois.
Minikube
Ouvrez le terminal dans le dossier où se trouve le fichier Vagrant.
Comment bien se former à
Kubernetes
Configurez Git pour lui faire savoir qui vous êtes, en entrant votre nom et votre
adresse email :
Comment utiliser Github dans
son labo DevOps
Page 21 of 45
E-handbook
Page 22 of 45
E-handbook
Les fichiers des expériences de cet article peuvent être clonés depuis le dépôt
Dans ce guide GitHub :
Page 23 of 45
E-handbook
Clonez les fichiers puis copiez-les dans le dossier de votre projet. Enfin, rendez
Dans ce guide tous les scripts shell exécutables :
Page 24 of 45
E-handbook
Une fois Git installé, la prochaine étape est de maîtriser ces cinq commandes
Démarrer avec Ansible pour
de base de Git : init, config, add, status et commit. Ce tutoriel Git pour
configurer son labo DevOps
débutants vous guidera pas à pas à travers chacune de ces commandes.
L’essor La première des cinq commandes de base est init. Cette commande de
base initialise un dépôt Git.
Page 25 of 45
E-handbook
Page 26 of 45
E-handbook
Comment créer son cluster C'est probablement la moins intéressante des cinq commandes basiques de
Kubernetes en local avec Git. Si vous venez d'installer Git, vous ne pouvez pas lancer une commande
Minikube commit sans d'abord configurer votre nom et votre adresse email. Cela se fait
avec la commande config git.
Comment bien se former à
Kubernetes Après avoir installé Git mais avant de pouvoir valider un code, Git a besoin de
connaître le nom et l'adresse email du committer. Cela signifie qu'il faut
Comment utiliser Github dans exécuter deux fois la commande git config. Pour la première exécution, utilisez
son labo DevOps l'attribut user.name, et la deuxième fois, l'attribut user.email.
Page 27 of 45
E-handbook
Page 28 of 45
E-handbook
Dans ce guide
Les données de configuration du système Git sont sauvegardées dans le sous-dossier etc de
Démarrer avec Ansible pour
l'installation.
configurer son labo DevOps
Page 29 of 45
E-handbook
Comment créer son cluster Vous n'avez pas besoin de committer tous les fichiers au contrôle du code
Kubernetes en local avec source. Avant qu'un développeur ne fasse un commit, il doit explicitement
Minikube identifier les fichiers à regrouper dans le cadre du commit. Ceci s’effectue en
lançant une commande git add avec le nom des fichiers à inclure dans le
Comment bien se former à prochain commit.
Kubernetes
Page 30 of 45
E-handbook
Cependant, malgré le fait que les trois fichiers résident dans le même répertoire
Dans ce guide - là où le dépôt Git a été initialisé -, seuls ceux associés à une commande git
add feront partie du prochain commit. Donc, si nous voulons laisser le fichier
Comment créer son cluster command.html en dehors du prochain commit, nous ne l'identifierons tout
Kubernetes en local avec
simplement pas dans un appel git add.
Minikube
/c/ basic git commands (tutorial)
Comment bien se former à $ git add basic.html
Kubernetes
/c/ basic git commands (tutorial)
Comment utiliser Github dans $ git add five.html
son labo DevOps
Il existe un terme technique pour identifier les fichiers qui feront partie de la
prochaine livraison : le staging. Lorsque vous lancez une commande git add sur
Git : 5 commandes basiques
que l’on doit maîtriser un fichier, vous avez placé le fichier dans l'index Git. L'index Git est ce qui
garde la trace de tous les fichiers à inclure dans le prochain commit.
Démarrer avec Ansible pour
Si vous avez modifié un grand nombre de fichiers et que vous voulez les placer
configurer son labo DevOps
en staging, vous pouvez lancer la commande git add[space]. Ceci ajoutera
chaque fichier modifié à l'index, à l'exception de tout ce qui est répertorié dans
le fichier .gitignore.
Page 31 of 45
E-handbook
Comment créer son cluster Parfois, les développeurs perdent la trace de ce qu'ils ont ou n'ont pas ajouté à
Kubernetes en local avec la zone de staging. C'est pourquoi nous incluons git status à ce tutoriel. Cette
Minikube commande indiquera sur quelle branche vous êtes, quels fichiers sont en
staging et quels fichiers restent non suivis et n'ont pas été ajoutés à l'index. La
Comment bien se former à commande git status est un excellent outil pour comprendre rapidement l'état
Kubernetes actuel de votre travail.
Comment utiliser Github dans Apprenez la commande d'état de git pour pouvoir afficher l'état de l'arborescence de travail.
son labo DevOps
Page 32 of 45
E-handbook
Page 33 of 45
E-handbook
Page 34 of 45
E-handbook
Comment créer son cluster Pour apprendre Ansible, il convient d’installer certains prérequis : Ansible sur la
Kubernetes en local avec VM maître et Python sur les nœuds. Pour les besoins de cet article, l'outil de
Minikube gestion de configuration a été associé à Vagrant - l'installation fait partie du
processus de provisioning de Vagrant :
Comment bien se former à
Kubernetes
Page 35 of 45
E-handbook
node1 et node2 utilisent ce même script pour installer Python, qui fournit
Dans ce guide l'environnement d'exécution d'Ansible. Pour la VM maître, utilisez un script
différent appelé ansible.sh pour installer Ansible ainsi que Python. Vous avez
Comment créer son cluster déjà créé les VMs, alors utilisez la commande vagrant provision pour que
Kubernetes en local avec
Vagrant exécute ces scripts. Utilisez vagrant destroy, puis vagrant up
Minikube
pour avoir un déploiement propre.
Comment bien se former à Une fois la configuration d’Ansible finalisée, committez à Git en ajoutant les
Kubernetes deux nouveaux fichiers script shell (.sh) puis en validant les modifications :
Page 36 of 45
E-handbook
Ce laboratoire DevOps nécessite une authentification par clé RSA pour que
Dans ce guide l'utilisateur de la VM maître puisse se connecter (SSH) dans les nœuds sans
mot de passe.
Comment créer son cluster
Kubernetes en local avec C'est ainsi qu'Ansible gère la configuration sans agent : Il se connecte via SSH
Minikube et exécute des commandes.
Page 37 of 45
E-handbook
Page 38 of 45
E-handbook
Page 39 of 45
E-handbook
Les deux nœuds doivent répondre par un pong, qui vérifie que la connexion
SSH fonctionne et que l'inventaire contient les bonnes adresses IP.
Page 40 of 45
E-handbook
Page 41 of 45
E-handbook
Page 42 of 45
E-handbook
Dans cet exemple, deux tâches ont été effectuées pour chaque nœud : la tâche
Dans ce guide d'installation est un test – il vérifie que l'utilisateur peut bien parler au nœud –,
puis la tâche ping s'exécute.
Comment créer son cluster
Kubernetes en local avec La tâche ping est redondante, car la tâche d'installation vérifie qu'Ansible
Minikube fonctionne. Les playbooks peuvent contenir des centaines de lignes de tâches.
Page 43 of 45
E-handbook
L’offre PRO+ est gratuite et réservée aux membres du réseau de sites internet
Comment bien se former à TechTarget.
Kubernetes
Comment utiliser Github dans Profitez de tous les avantages liés à votre
son labo DevOps abonnement sur: http://www.lemagit.fr/eproducts
Images : Fotolia
Git : 5 commandes basiques
que l’on doit maîtriser ©2018 TechTarget. Tout ou partie de cette publication ne peut être transmise ou reproduite dans quelque forme ou de
quelque manière que ce soit sans autorisation écrite de la part de l’éditeur.
Page 44 of 45
E-handbook
Dans ce guide
©2018 TechTarget Inc. Aucun des contenus ne peut être transmis ou reproduit quelle que soit la forme sans l'autorisation écrite de
Git : 5 commandes basiques l'éditeur. Les réimpressions de TechTarget sont disponibles à travers The YGS Group.
que l’on doit maîtriser TechTarget édite des publications pour les professionnels de l'IT. Plus de 100 sites qui proposent un accès rapide à un stock important
d'informations, de conseils, d'analyses concernant les technologies, les produits et les process déterminants dans vos fonctions. Nos
événements réels et nos séminaires virtuels vous donnent accès à des commentaires et recommandations neutres par des experts sur
les problèmes et défis que vous rencontrez quotidiennement. Notre communauté en ligne "IT Knowledge Exchange" (Echange de
Démarrer avec Ansible pour connaissances IT) vous permet de partager des questionnements et informations de tous les jours avec vos pairs et des experts du
secteur.
configurer son labo DevOps
Page 45 of 45