Ansible - Dépannage

Les stratégies les plus courantes pour le débogage des playbooks Ansible utilisent les modules ci-dessous -

Déboguer et enregistrer

Ces deux modules sont disponibles dans Ansible. À des fins de débogage, nous devons utiliser judicieusement les deux modules. Des exemples sont présentés ci-dessous.

Utiliser la verbosité

Avec la commande Ansible, on peut fournir le niveau de verbosité. Vous pouvez exécuter les commandes avec un niveau de verbosité un (-v) ou deux (-vv).

Les points importants

Dans cette section, nous allons passer en revue quelques exemples pour comprendre quelques concepts.

Si vous ne citez pas un argument commençant par une variable. Par exemple,

vars: 
   age_path: {{vivek.name}}/demo/ 
   
{{vivek.name}}

Cela lancera une erreur.

Solution

vars: 
   age_path: "{{vivek.name}}/demo/" – marked in yellow is the fix. 
 
How to use register -> Copy this code into a yml file say test.yml and run it  
--- 
#Tsting 
- hosts: tomcat-node 
   tasks: 
 
   - shell: /usr/bin/uptime 
      register: myvar 
      - name: Just debugging usage 
         debug: var = myvar

Lorsque j'exécute ce code via la commande Ansible-playbook -i hosts test.yml, j'obtiens la sortie comme indiqué ci-dessous.

Si vous voyez le yaml, nous avons enregistré la sortie d'une commande dans une variable - myvar et vient d'imprimer la sortie.

Le texte marqué en jaune nous informe sur la propriété de la variable –myvar qui peut être utilisée pour un contrôle de flux supplémentaire. De cette façon, nous pouvons découvrir les propriétés exposées d'une variable particulière. La commande de débogage suivante aide à cela.

$ ansible-playbook -i hosts test.yml 

PLAY [tomcat-node] ***************************************************************
**************** ****************************************************************
*************** ****************************** 
 
TASK [Gathering Facts] *****************************************************************
************** *****************************************************************
************** ************************** 
Monday 05 February 2018  17:33:14 +0530 (0:00:00.051) 0:00:00.051 ******* 
ok: [server1] 
 
TASK [command] ******************************************************************
************* ******************************************************************
************* ********************************** 
Monday 05 February 2018  17:33:16 +0530 (0:00:01.697) 0:00:01.748 ******* 
changed: [server1] 
 
TASK [Just debugging usage] ******************************************************************
************* ******************************************************************
************* ********************* 
Monday 05 February 2018  17:33:16 +0530 (0:00:00.226) 0:00:01.974 ******* 
ok: [server1] => { 
   "myvar": { 
      "changed": true, 
      "cmd": "/usr/bin/uptime", 
      "delta": "0:00:00.011306", 
      "end": "2018-02-05 17:33:16.424647", 
      "rc": 0, 
      "start": "2018-02-05 17:33:16.413341", 
      "stderr": "", 
      "stderr_lines": [], 
      "stdout": " 17:33:16 up 7 days, 35 min,  1 user,  load average: 0.18, 0.15, 0.14", 
      "stdout_lines": [ 
         " 17:33:16 up 7 days, 35 min,  1 user,  load average: 0.18, 0.15, 0.14" 
      ] 
   } 
} 
 
PLAY RECAP ****************************************************************************
**********************************************************************************
 ************************************** 
server1 : ok = 3    changed = 1    unreachable = 0    failed = 0

Problèmes courants de Playbook

Dans cette section, nous découvrirons les quelques problèmes courants du playbook. Les problèmes sont -

  • Quoting
  • Indentation

Playbook est écrit au format yaml et les deux problèmes ci-dessus sont les problèmes les plus courants dans yaml / playbook.

Yaml ne prend pas en charge l'indentation basée sur les tabulations et prend en charge l'indentation basée sur l'espace, il faut donc faire attention à la même chose.

Note - une fois que vous avez terminé d'écrire le yaml, ouvrez ce site (https://editor.swagger.io/) et copiez-collez votre yaml sur le côté gauche pour vous assurer que le yaml se compile correctement. Ceci n'est qu'un conseil.

Swagger qualifie les erreurs d'avertissement ainsi que les erreurs.