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_hoststous 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.

21
demandé sur Roopendra 2014-07-17 12:23:30

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
24
répondu Yuichiro 2014-07-18 16:51:32

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
9
répondu anneb 2015-03-23 17:25:57

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'
6
répondu tima 2014-07-17 15:40:34

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