CI/CD d'une infra
Apprendre des technologies pour l'infra et savoir le faire avec qualité
🗓️ Dernière maj le 14 octobre 2020
Le but de ce TP est de monter une pipeline de test d'infra et de code d'infra (Ansible) maison. Le tp permet de vous apprendre certaine technologie, au menu :
outil de versioning (SCM)
application permettant d'héberger des dépôtss Git
léger
expose une WebUI
application permettant de mettre en place des pipelines de test/build
s'intègre nativement avec Gitea
outil de gestion et déploiement de configuration
très utilisé aujourd'hui, c'est l'outil de référence en la matière
outil qui se couple à Ansible pour effectuer des tests sur les playbooks
en particulier des tests de conformité
application de conteneurisation
permet de créer des environnements légers et autonomes
0. Setup environment
Poste de travail
Machines virtuelles
Images Docker
I. Setup environnement Git
II. Mise en place de Drone
III. Ansible
0. Structure du dépôt Ansible
1. Création de playbooks
2. Premiers tests
3. Molecule
Présentation
Prise en main
Setup dans la pipeline
0. Setup environment
Poste de travail
Pendant le TP, je vous conseille d'utiliser une machine GNU/Linux comme "poste de travail". Si vous avez un GNU/Linux en dur c'est OK, sinon je vous recommande une VM "poste de travail" (un CentOS peut faire l'affaire).
En soit aucun pb pour utiliser un autre OS, il faut simplement être à l'aise pour l'utilisation de git
, docker
, Python pip
, et ansible
, sur votre machine.
Machines virtuelles
L'OS conseillé pour les VMs en cours est CentOS7. Afin de faciliter et accélérer le déploiement, on va utiliser Vagrant.
Téléchargez Vagrant pour votre OS, puis initialisez une box centos/7
:
Il peut être bon de repackager la box avec certains éléments préconfigurés, afin de gagner du temps à chaque destroy/up, par exemple :
Je vous conseille notamment d'installer Docker dans votre box repackagée, on en aura souvent besoin par la suite.
Une fois repackagée, il est possible d'utiliser la box comme base dans un Vagrantfile :
Images Docker
Pour ce qui est des images Docker, on va beaucoup réutiliser d'images déjà packagées par la communauté. Cela nous permettra d'aller un peu plus vite dans le TP, sans perdre du temps à écrire des Dockerfiles et build des images sur mesure.
I. Setup environnement Git
EDIT : vous pouvez utiliser le fichier docker-compose.yml :
Qui permet de monter facilement Gitea + Drone afin d'accélérer vos tests.
Pour ce qui est du dépôt git, on va utiliser Gitea. C'est une app minimaliste développée en go, qui permet d'héberger des dépôts Git.
Loin d'être fully-featured comme un Gitlab, Gitea opte plutôt pour un aspect modulaire : Gitea lui-même ne se charge que de gérer les dépôts git et leurs accès, il faudra lui greffer d'autres applications afin qu'ils profitent de fonctionnalités supplémentaires.
TO DO : écrire un Vagrantfile qui monte une machines virtuelle CentOS7
la VM va porter Gitea, Drone et run des jobs de build/test
SELinux doit être désactivé
2048M RAM sont conseillés
pour lancer les services, libres à vous :
en dur
dans des conteneurs Docker (je vous le conseille, plus rapide et plus simple à faire évoluer pour faire joujou pendant le TP)
TO DO : mettre en place Gitea
installer Gitea en suivant la doc officielle
je vous conseille un conteneur Docker pour plus de flexibilité
N'oubliez pas de créer un utser admin lors de la première connexion à la WebUI
TO DO : Effectuer un push une fois que Gitea est fonctionnel
créer un premier dépôt de test
effectuer un premier push pour valider le bon fonctionnement de la solution
II. Mise en place de Drone
Drone est un outil léger permettant de mettre en place des pipelines de build et de test. Il se couple nativement très bien avec Gitea.
Comme beaucoup d'outils en son genre, il fonctionne sur un principe de master/runner :
le master expose la GUI, reçoit les ordres de build et de test, et demandent aux runners d'exécuter des tâches
le runner a pour charger d'exécuter les tâches demandées par le master : c'est lui qui effectue les builds/tests
on va utilise un runner de type Docker
c'est à dire que le serveur sera capable de lancer des conteneurs Docker afin d'y effectuer des tests
Dans le cadre du TP, ce sera la même VM qui portera le master et un runner Docker.
TO DO : configurer Drone pour le lier à Gitea
Les credentials sont les mêmes que l'utilisateur admin de Gitea.
TO DO : tester une première pipeline de test
créer un dépôt git dans la WebUI de Gitea
synchroniser le dépôt depuis l'interface de Drone
préciser que le dépôt est Trusted (paramètres du dépôt dans la WebUI de Drone)
cloner le projet
placer à la racine un fichier
.drone.yml
qui contient :
push le fichier
se rendre sur la WebUI de Drone pour voir le résultat
III. Ansible
Ansible est un outil de gestion et déploiement de configuration. Il permet de contrôler de façon centralisée et uniformisée un parc de machines. C'est désormais la techno open-source de référence pour ce qui est de la gestion de configuration.
Techno très demandée aujourd'hui, nous allons l'utiliser comme base afin de mettre en place des pipelines de CI/CD.
On ne va pas, dans ce cours, approfondir Ansible. Le but est simplement d'avoir des fichiers de code à tester, des applicatons à tester, build, et intégrer, mais aussi manipuler une technologie extrêmement demandée.
Quelques impératifs pour qu'Ansible fonctionne :
les fichiers Ansible sont au format
yml
à l'intérieur de ces fichiers, on décrit ce qu'il faut installer et configurer sur les serveurs de destination
la machine qui possède les fichiers
.yml
doit pouvoir se connecter en SSH sur les serveurs de destinationl'utilisateur sur les serveurs de destination doit pavoir accès à des droits root (via
sudo
par exemple)nécessaires pour beaucoup d'actions comme l'installation de paquets
0. Structure du dépôt Ansible
Vous devrez organiser votre dépôt Ansible selon un format standard :
Directory
Usage
inventory/
Contient l'inventaire des machines et les variables qui y sont liées
roles/
Contient l'ensemble des "roles" Ansible. Un "role" est un ensemble de tasks ayant un sens (par exemple un rôle "Apache" ou "MySQL")
playbooks/
La glu entre l'inventaire et les rôles : les playbooks décrivent quel rôle appliquer sur quelle machine
1. Création de playbooks
TO DO : setup Ansible
s'assurer que Python est installé sur les machines de destination
s'assurer qu'il existe un utilisateur pouvant accéder aux droits de root à l'aide de
sudo
sur les machines de destinationconfigurer un échange de clés SSH entre le poste de travail (qui héberge les fichiers
yml
Ansible) et les machines de destination
TO DO : un premier playbook
créer un inventaire contenant la machine à qualifier
créer un rôle qui installe et configure un serveur NGINX
créer un playbook qui permet de déployer le rôle NGINX sur la machine déclarée dans votre inventaire
Le dépôt Ansible est à déposer dans un endroit personnel (le homedir de votre utilisateur par exemple).
Exemple de structure de dépôt Ansible :
Structure du fichier inventory/ci/hosts.yml
:
Structure du fichier playbooks/test.yml
:
Structure du fichier roles/nginx/tasks/main.yml
:
Contenu de roles/nginx/files/start_nginx.sh
TO DO : tester le bon déploiement du service NGINX et vérifier que le serveur Web est bien fonctionnel
NB : nous travaillerons essentiellement avec des conteneurs pour les tests. Or il n'existe pas de gestion de services (comme systemd) dans les conteneurs Vous ne pourrez donc pas utiliser quelque chose comme
systemctl start nginx
afin de démarrer NGINX. Le scriptstart_nginx.sh
est donc utilisé pour lancer le serveur.
2. Premiers tests
TO DO : tester le code ansible
créer un dépôt dans Gitea, dédié à hébergé votre code Ansible
créer un fichier
.drone.yml
qui teste la validité des fichier Ansiblele linter ansible-lint est parfait pour ce use-case
pousser le fichier
.drone.yml
pour déclencher une pipeline
TO DO : ajouter un rôle
ajouter un rôle qui déploie des utilisateurs, et le pousser sur le dépôt, afin de tester la pipeline
3. Molecule
Présentation
Molecule est un outil qui se couple à Ansible afin d'effectuer des tests d'infra et de conformité.
Le but de cette partie est d'effectuer des tests, à l'aide Molecule, sur le déploiement du rôle Ansible.
Le fonctionnement de Molecule est simple :
créer un environnement de test (conteneur, VM)
dérouler un rôle dans l'environnement
vérifier le bon déroulement du playbook
Par "vérifier le bon déroulement du playbook", on entend : vérifier que le playbook passe, que l'environnement est conforme à nos attentes après déroulement du playbook (est-ce que tel paquet a été bien installé ou tel port firewall a été correctement ouver) ou encore vérifier l'idempotence du playbook (en l'exécutant deux fois d'affilée).
Prise en main
Afin de prendre en main Molecule, il peut être bon de tester quelques commandes à la main.
TO DO : Installer Molecule (je vous recommande l'installation avec pip
).
Molecule va nous permettre ici de tester le rôle nginx
que nous venions d'écrire. Pour que Molecule accepte de tester notre rôle, il est nécessaire d'y ajouter quelques fichiers. Molecule permet de créer un rôle possédant une structure qui correspond aux bonnes pratiques Ansible, afin d'être testé correctement. Pour ce faire :
Le rôle est alors prêt à être tester :
Setup dans la pipeline
TO DO : créer une pipeline qui utilise Molecule
éditer le
drone.yml
la pipeline doit utiliser une image Docker qui contient Molecule
image officielle :
quay.io/ansible/molecule:3.0.8
le test de la pipeline doit exécuter un
molecule test
pour ce faire, vous allez devoir permettre au conteneur molecule de lui-même lancer des conteneurs. On peut le faire en montant le socket Docker
/var/run/docker.sock
dans le conteneur Molecule pour qu'il puisse lancer des conteneurs sur l'hôte
Auteur du TP et intervenant professionnel auprès des écoles du supérieur :
Note de coté pour Léolios :
Dernière mise à jour