ansible
Ansible: Looping
Recherche…
with_items - liste simple
Une boucle with_items
dans ansible peut être utilisée pour boucler facilement les valeurs.
- name: Add lines to this file
lineinfile: dest=/etc/file line={{ item }} state=present
with_items:
- Line 1
- Line 2
- Line 3
with_items - liste prédéfinie
Vous pouvez également parcourir une liste de variables.
De vars:
favorite_snacks:
- hotdog
- ice cream
- chips
et puis la boucle:
- name: create directories for storing my snacks
file: path=/etc/snacks/{{ item }} state=directory
with_items: '{{ favorite_snacks }}'
Si vous utilisez Ansible 2.0+, vous devez utiliser des guillemets autour de l'appel à la variable.
with_items - dictionnaire prédéfini
Il est possible de créer des boucles plus complexes avec des dictionnaires.
De vars:
packages:
- present: tree
- present: nmap
- absent: apache2
alors la boucle:
- name: manage packages
package: name={{ item.value }} state={{ item.key }}
with_items: '{{ packages }}'
Ou, si vous n'aimez pas utiliser la valeur clé:
vars:
packages:
- name: tree
state: present
- name: nmap
state: present
- name: apache2
state: absent
alors la boucle:
- name: manage packages
package: name={{ item.name }} state={{ item.state }}
with_items: '{{ packages }}'
with_items - dictionnaire
Vous pouvez utiliser un dictionnaire pour une boucle légèrement plus complexe.
- name: manage packages
package: name={{ item.name }} state={{ item.state }}
with_items:
- { name: tree, state: present }
- { name: nmap, state: present }
- { name: apache2, state: absent }
Boucles imbriquées
Vous pouvez créer des boucles imbriquées à l'aide de with_nested
.
de vars:
keys:
- key1
- key2
- key3
- key4
alors la boucle:
- name: Distribute SSH keys among multiple users
lineinfile: dest=/home/{{ item[0] }}/.ssh/authorized_keys line={{ item[1] }} state=present
with_nested:
- [ 'calvin', 'josh', 'alice' ]
- '{{ keys }}'
Cette tâche fera une boucle sur chaque utilisateur et remplira son fichier authorized_keys
avec les 4 clés définies dans la liste.