Caradoc un outil de tracing Ansible
Je vous propose de découvrir caradoc, un callback Ansible qui peut vous aider à déboguer vos playbooks. Il n’est pas sans rappeler ARA, qui permet de stocker les traces de vos exécutions dans une base de données sqlite locale, voir sur un serveur distant.
Introduction
Je suis sûr que comme moi, vous galérez quand il s’agit de comprendre ce qui
plante dans une exécution de playbooks. On n’a jamais assez de traces et
celles rendues par le mode debug
est difficile à lire. C’est là qu’intervient
caradoc, un plugin écrit par Joël Seguillon.
Caradoc permet de créer des traces lisibles dans un répertoire local. Ces
traces sont écrites en asciidoc
, qui peut être rendu directement dans votre
éditeur de code favori. Par exemple moi, j’ai installé l’extension VsCode
AsciiDoctor ↗
Installation de caradoc
Tout est documenté dans le dépôt du projet ↗ :
À partir de là, vous pouvez ajouter le callback
à votre configuration ansible
(par exemple depuis là où se trouve vos playbooks) :
Lecture des traces produites
Si vous lancez l’exécution d’un playbook, vous devriez trouver dans votre
répertoire un dossier .caradoc
. Contenant les traces d’exécution.
Une fois l’extension Vscode installée, de cliquer sur le fichier README.adoc
d’une exécution et de sélectioner [Open Preview].
Le rendu est vraiment explicite.
Il suffit de naviguer dans les taches via les liens pour trouver toutes les traces de celles-ci.
Plus loin avec caradoc
J’imagine déjà l’utiliser dans mes pipelines de CI-CD, d’ailleurs, il suffit de s’inspirer de cette Github actions fournie par l’auteur :
Si vous avez des suggestions, créer simplement une issue sur le dépôt du projet ↗. On remercie Joël car ce callback va vous faire gagner du temps.