在Ansible中使用ipaddr过滤对象列表

时间:2019-05-07 13:13:58

标签: ansible jinja2

如果我在Ansible中有一个IP地址列表,则可以使用ipaddr过滤器对其进行过滤,并且只获取传回的值:

- debug:
    msg: "{{ ['127.0.0.1', 'foo', '2001:db8:32c:faad::'] | ipaddr('address') }}"

不幸的是,我正在使用对象列表(精确地说是组成员的 hostvars )。我想对列表进行一些测试,并且仅使条目通过-但作为对象。

在阅读Jinja文档时,我偶然发现了selectattr。不幸的是,看来ipaddr不是测试,所以它不起作用:

- debug:
    msg: "{{ [{'ip':'127.0.0.1'}, {'ip':'foo'}, {'ip':'2001:db8:32c:faad::'}] | selectattr('ip', 'ipaddr', 'address') | list}} "

产生

  

jinja2.exceptions.TemplateRuntimeError:没有名为“ ipaddr”的测试

是否可以使用ipaddr来过滤对象列表?

1 个答案:

答案 0 :(得分:4)

  

是否可以使用ipaddr过滤对象列表?

当然!您可以使用map函数将过滤器应用于列表,以获取(有效)true / false值的列表,然后将其与原始列表结合使用以选择仅具有有效地址的条目。例如:

---
- hosts: localhost
  gather_facts: false
  vars:
    addresses:
      - name: host0
        ip: 127.0.0.1
      - name: host1
        ip: foo
      - name: host2
        ip: '2001:db8:32c:faad::'
  tasks:
    - set_fact:
        valid_addresses: "{{ addresses|json_query('[*].ip')|map('ipaddr')|list }}"

    - debug:
        msg: "host {{ item.0.name }} has valid address {{ item.0.ip }}"
      when: item.1
      loop: "{{ addresses|zip(valid_addresses)|list }}"