在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"的服务器才会被处理。