Ne pas utiliser de module obsolète “Deprecated” (RA_QUA_N2)
Les noms de tâche devraient être uniques (RA_QUA_N3)
Si pas besoin des facts : mettre gather_facts à false (RA_PERF_N3)
Si besoin de facts récuper seulement les facts utiles (RA_PERF_N3)
Playbook pouvant fonctionner un Dry-Run (--check) (RA_TEST_N2)
Ne pas utilisez ignore_errors: true et encore moins pour un playbook entier. Préferez “failed_when:” (RA_QUA_N1)
Éviter d’utiliser delegate_to surtout, dans les rôles (RA_QUA_N1)
Pour les templates et les fichiers, systématiquement sauf si non applicable mettre en commentaire que ce fichier est géré par Ansible. (RA_QUA_N1)
Ne pas utiliser M(vars_prompt) (remplacé par les “Surveys” et extra-vars) (RA_QUA_N1)
Ne pas utiliser M(pause) sans timeout (RA_QUA_N1)
Utiliser des inventaires dynamiques (If you have an external source of truth) (RA_QUA_N3)
Larger Host Counts - Consider setting “forks” on a job template to larger values to increase parallelism of execution runs. Voir : Strategy, Mitogen, Slicing, Async (Asynchronous) (RA_PERF_N3)
Ne pas mettre les facts des nœuds dans la base de données - Ne pas activer “Enable Fact Storage” Le cache des facts doit être sur les managed_hosts et non coté serveur (RA_GEN_N1)
Ne pas faire de command: ansible-galaxy ni de shell: ansible-galaxy, mais utiliser la manière native de AAP / AWX (RA_QUA_N1)
Pour les facts (facts caching) (RA_PERF_N3)
Assert extra_var, controler les inputs des utilisateurs (RA_SEC_N1)
Assert sur les cibles (RA_SEC_N2)
-
Utiliser SonarQube ou équivalent (RA_GEN_N4)
Utiliser l'encodage UTF8 (RA_GEN_N1)
Remplacer les tabulations par 2 espaces (A config si ce n'est pas le cas dans l'IDE) (RA_GEN_N1)
DRY - Factoriser - Éviter de dupliquer du code - Don't Repeat Yourself (DRY) (RA_GEN_N3) Dans la mesure du possible, seulement se répéter est mieux que d'écrire un code difficilement lisible. Car “à la pureté, privilégie l'aspect pratique.”
Mettre les become_user: root que sur les tâches nécessitant les privilèges, et non sur tous le playbook (RA_SEC_N1)
Utiliser no_log: true pour les taches utilisant des secrets (RA_SEC_N1)
Pour les données sensibles utiliser ansible-vault ou les Crendential AWX (RA_SEC_N1)
Mettre en cache les facts (fact_caching) (mais sur les noeuds, pas en DB) (RA_PERF_N3)
Eviter de boucler innutilement - vérifier si le module prends des listes (RA_PERF_N2)
Nommer les templates Jinja avec l’extension j2 (RA_CONV_REQ)
Préférer les variables a plat plutôt que les variables dictionnaires (RA_CONV_OPT)
De préférence nommer la variable de boucle (loop_var) à la place d'utiliser le nom par défaut item (RA_CONV_OPT)
? Pour les roles contenants beaucoup de fichiers dans “files/” privilégier une arborescence comme suit (RA_CONV_OPT) (ex files/etc/nginx/sites-available/plop)