有这样的字典:
ossec_datacenter:
atlanta:
hostname: 'server1.fakedomain.net'
ip: '192.168.12.170'
port: '1515'
miami:
hostname: 'server2.fakedomain.net'
ip: '192.168.20.31'
port: '1514'
dallas:
hostname: 'server2.fakedomain.net'
ip: '192.168.20.20'
port: '1515'
如何在when
子句中搜索此词典中的所有值?
我可以使用ossec_datacenter[ossec_dc]['hostname']
但我想搜索所有值以确保不存在匹配。
换句话说,我不希望在该数据结构中的任何地方找到inventory_hostname
和IP。
答案 0 :(得分:4)
如果你想使用json_query(需要ansible 2.2),你可以这样做来搜索ip和hostname:
- name: find inventory_hostname
set_fact:
found: True
with_items:
- "{{ ossec_datacenter | json_query('*.ip') }}"
- "{{ ossec_datacenter | json_query('*.hostname') }}"
when: "inventory_hostname == item"
或者如果要搜索数据中心(ip,hostname或port)中的任何键:
- name: find inventory_hostname
set_fact:
found: True
with_items: "{{ ossec_datacenter | json_query('*.*') }}"
when: "inventory_hostname == item"
然后测试found
var。
答案 1 :(得分:3)
这是主机名的条件:
when: inventory_hostname not in (ossec_datacenter.values() | map(attribute='hostname') | list)
使用ansible_default_ipv4.address
或其他一些有关IP地址的事实,并使用map(attribute='ip')
减少您的字典以搜索IP地址。