在Ansible中,可以使用when
子句进行条件判断,并与json_query
和loop
配合使用。
下面是一个示例,假设有一个JSON数据如下:
{
"servers": [
{
"name": "server1",
"status": "running"
},
{
"name": "server2",
"status": "stopped"
},
{
"name": "server3",
"status": "running"
}
]
}
我们想要在Ansible中遍历这些服务器,并仅对status为"running"的服务器执行一些操作。
可以使用以下代码示例实现:
- name: Example task
hosts: localhost
gather_facts: false
tasks:
- name: Load JSON data
set_fact:
servers: "{{ lookup('file', 'path/to/json_file.json') | from_json }}"
- name: Loop through servers
debug:
msg: "Processing server {{ item.name }}"
loop: "{{ servers.servers }}"
when: item.status == 'running'
在示例中,首先使用set_fact
模块将JSON数据加载到变量servers
中。然后使用loop
迭代servers.servers
列表,并使用when
子句检查每个服务器的status
是否为"running"。如果满足条件,则执行debug
模块,输出服务器的名称。
这样,只有status
为"running"的服务器才会被处理。