Comment affecter un tableau à une variable dans un Ansible-Playbook
Dans un playbook j'ai le code suivant:
---
- hosts: db
vars:
postgresql_ext_install_contrib: yes
postgresql_pg_hba_passwd_hosts: ['10.129.181.241/32']
...
je voudrais remplacer la valeur de postgresql_pg_hba_passwd_hosts
tous mes serveurs privés ips. Je comprends que je peux obtenir les valeurs de la forme dans un template:
{% for host in groups['web'] %}
{{ hostvars[host]['ansible_eth1']['ipv4']['address'] }}
{% endfor %}
Quelle est la façon la plus simple/la plus facile de affecter le résultat de cette boucle à une variable dans un playbook<!--8? Ou y a-t-il une meilleure façon de recueillir ces renseignements? Dois-je mettre cette boucle dans un modèle?
défi supplémentaire: je devrais ajouter /32
pour chaque entrée.
5 réponses
vous pouvez affecter une liste à la variable par set_fact et ansible filtre plugin.
filtre personnalisé plugin filter_plugins dossier comme ceci:
(ansible top directory)
site.yml
hosts
filter_plugins/
to_group_vars.py
to_group_vars.py convertissez hostvars dans la liste qui a sélectionné par groupe.
from ansible import errors, runner
import json
def to_group_vars(host_vars, groups, target = 'all'):
if type(host_vars) != runner.HostVars:
raise errors.AnsibleFilterError("|failed expects a HostVars")
if type(groups) != dict:
raise errors.AnsibleFilterError("|failed expects a Dictionary")
data = []
for host in groups[target]:
data.append(host_vars[host])
return data
class FilterModule (object):
def filters(self):
return {"to_group_vars": to_group_vars}
Utiliser comme ceci:
---
- hosts: all
tasks:
- set_fact:
web_ips: "{{hostvars|to_group_vars(groups, 'web')|map(attribute='ansible_eth0.ipv4.address')|list }}"
- debug:
msg: "web ip is {{item}}/32"
with_items: web_ips
dans playbook:
vars:
- arrayname:
- name: itemname
value1: itemvalue1
value2: itemvalue2
- name: otheritem
value1: itemvalue3
value2: itemvalue4
dans le modèle: (l'exemple est un type de fichier ini, avec des sections, des clés et des valeurs):
{% for item in arrayname %}
[{{ item.name }}]
key1 = {{ item.value1 }}
key2 = {{ item.value2 }}
{% endfor %}
Cela devrait rendre le modèle:
[itemname]
key1 = itemvalue1
key2 = itemvalue2
[otheritem]
key1 = itemvalue3
key2 = itemvalue4
Les Variables peuvent être représentées comme des structures YAML standard de sorte que vous pouvez assigner une valeur de liste à une clé comme celle-ci:
---
- hosts: db
vars:
postgresql_ext_install_contrib: yes
postgresql_pg_hba_passwd_hosts:
- '10.129.181.241/32'
- '1.2.3.0/8'
vous pouvez utiliser les filtres jinja2:
{{ groups['nodes']|map('extract', hostvars, ['ansible_eth1','ipv4', 'address']) |list }}
retourne une liste d'adresses ip. i.e.
---
- hosts: db
vars:
postgresql_ext_install_contrib: yes
postgresql_pg_hba_passwd_hosts: {{ groups['nodes']|map('extract', hostvars, ['ansible_eth1','ipv4', 'address']) |list }}
...
N'inclut pas le challange (annexe