如何循环ansible json_查询
有没有办法简化下面的json_查询? 在这里,您可以看到我正试图使用三种查询设置来提取三个值。由于列表中有三个项目,因此该值将与项目列表对应生成三次。有没有办法将每个项目的值分开如何循环ansible json_查询,ansible,ansible-2.x,ansible-facts,json-query,Ansible,Ansible 2.x,Ansible Facts,Json Query,有没有办法简化下面的json_查询? 在这里,您可以看到我正试图使用三种查询设置来提取三个值。由于列表中有三个项目,因此该值将与项目列表对应生成三次。有没有办法将每个项目的值分开 ClusterName: xxxx for dv-cn-c1 DomainName: xxxx for dv-cn-c1 ClusterName: xxxx for dv-cn-c2 DomainName: xxxx for dv-cn-c2 请看我的想法 - name: "set fact for poli
ClusterName: xxxx for dv-cn-c1
DomainName: xxxx for dv-cn-c1
ClusterName: xxxx for dv-cn-c2
DomainName: xxxx for dv-cn-c2
请看我的想法
- name: "set fact for policy pkg for list of devices"
set_fact:
ClusterName: "{{ fullinvt | json_query(query1) }}"
DomainName: "{{ fullinvt | json_query(query2) }}"
PolicyName: "{{ fullinvt | json_query(query3) }}"
vars:
#w query: "ansible_facts.checkpoint_servers_gateways.objects[*].policy[].\"cluster-members-access-policy-revision\"[?name == 'dev-cn-c2'].name"
query1: "ansible_facts.checkpoint_servers_gateways.objects[?\"cluster-member-names\"[?contains(@ `{{ item }}`)]].name | [0]"
query2: "ansible_facts.checkpoint_servers_gateways.objects[?\"cluster-member-names\"[?contains(@ `{{ item }}`)]].domain.name | [0]"
query3: "ansible_facts.checkpoint_servers_gateways.objects[?\"cluster-member-names\"[?contains(@ `{{ item }}`)]].policy.\"access-policy-name\" | [0]"
with_items:
- dv-cn-c1
- dv-cn-c2
- dv-cn-4
tags: ADDLAG
您可以做的是构建一个字典字典,其中第一级键是循环中的项;第二级键对应的
ClusterName
、DomainName
和PolicyName
值
我创建了一个示例playbook
,以更好地解释自己:
---
- name: Multiple json_queries
hosts: local
connection: local
gather_facts: no
vars_files:
- ./secret.yml
vars:
fullinvt:
dv-cn-c1:
ClusterName: dv-cn-c1-cluster-name
DomainName: dv-cn-c1-domain-name
PolicyName: dv-cn-c1-policy-name
dv-cn-c2:
ClusterName: dv-cn-c2-cluster-name
DomainName: dv-cn-c2-domain-name
PolicyName: dv-cn-c2-policy-name
dv-cn-4:
ClusterName: dv-cn-4-cluster-name
DomainName: dv-cn-4-domain-name
PolicyName: dv-cn-4-policy-name
tasks:
- name: Create `json_query` object
set_fact:
# Multiline filter application
result: >
{{
(result | default({})) |
combine({item: {
"ClusterName": fullinvt | json_query('"' + item + '"' + ".ClusterName"),
"DomainName": fullinvt | json_query('"' + item + '"' + ".DomainName"),
"PolicyName": fullinvt | json_query('"' + item + '"' + ".PolicyName")
}})
}}
loop:
- dv-cn-c1
- dv-cn-c2
- dv-cn-4
- debug:
var: item
loop: "{{ result | dict2items }}"
我没有创建全局事实,而是创建了一个名为result
。循环中每个元素的数据都位于具有相同名称的键内
如果需要进一步循环此词典,可以使用dict2items
过滤器,如debug
任务所示
我希望这会有帮助。据我所知,你只能设定一次事实。但是由于使用_items迭代
,您将多次设置相同的事实。因此,您的任务不会像您预期的那样工作。