Ansible - 将 group_vars 和 host_vars 中的变量一起放入列表中
Ansible - get variables from group_vars and host_vars together into a list
我正在尝试从清单组中获取 IP 地址列表而不是主机名。这些 IP 地址已经在我的 hostvars 中,但我无法让它们匹配来自其组名的列表。
这是我的原始剧本:
- name: Install Kafka
hosts: kafka
roles:
- role: kafka
kafka_hosts: "{{ groups['kafka'] | list }}"
kafka_zookeeper_hosts: "{{ groups['zookeeper'] | list }}"
如您所见,kafka_hosts 和 kafka_zookeeper_hosts 是列表。
这个剧本对我的服务器配置的结果是正确的:
/etc/kafka/consumer.properties:zookeeper.connect=opo-4:2181,opo-5:2181,opo-6:2181
/etc/kafka/producer.properties:metadata.broker.list=opo-1:9092,opo-2:9092,opo-3:9092
不幸的是,由于 DNS 问题,此配置不适用于我的所有服务器。我需要一个 IP 地址列表而不是主机名。
如果我在我的 playbook 中手动设置 IP 地址,我的配置有效,不幸的是不是动态的:
kafka_hosts:
- 192.168.48.1
- 192.168.48.2
- 192.168.48.3
kafka_zookeeper_hosts:
- 192.168.48.4
- 192.168.48.5
- 192.168.48.6
我的服务器上的结果使它 有效 :
/etc/kafka/consumer.properties:zookeeper.connect=192.168.48.4:2181,192.168.48.5:2181,192.168.48.6:2181
/etc/kafka/producer.properties:metadata.broker.list=192.168.48.1:9092,192.168.48.2:9092,192.168.48.3:9092
在此配置中,我必须使用相同的信息手动维护我的组 和 我的剧本。所以我想从 kafka 和 zookeeper.
组中获取 hostvars
这里是 hostvars 和组,在主清单文件中定义:
[opo]
opo-1 ansible_host=192.168.48.1
opo-2 ansible_host=192.168.48.2
...
opo-6 ansible_host=192.168.48.6
[zookeeper]
opo-1
opo-2
opo-3
[kafka]
opo-4
opo-5
opo-6
我尝试过的 - 基于类似问题在 Whosebug 上找到的答案:
- kafka_hosts:“{{组[['kafka']['ansible_host']] |列表}}”
- kafka_hosts: "{{ [hostvars[groups['kafka'][0]]['ansible_host']] | list }}" #列表只包含第一个ip地址
- kafka_hosts:“{{ [hostvars[groups['kafka']]['ansible_host']] | list }}”
- kafka_hosts: "{{ hostvars[groups['kafka']].ansible_host | list }}"
- kafka_hosts: "{{ [hostvars.[groups['kafka']].ansible_host] | list }}"
- kafka_hosts:“{{组['kafka'].ansible_host |列表}}”
其中 None 给出了预期的 IP 地址列表。
您需要使用extract
and map
combination:
kafka_hosts: "{{ groups['kafka'] | map('extract',hostvars,'ansible_host') | list }}"
我正在尝试从清单组中获取 IP 地址列表而不是主机名。这些 IP 地址已经在我的 hostvars 中,但我无法让它们匹配来自其组名的列表。
这是我的原始剧本:
- name: Install Kafka
hosts: kafka
roles:
- role: kafka
kafka_hosts: "{{ groups['kafka'] | list }}"
kafka_zookeeper_hosts: "{{ groups['zookeeper'] | list }}"
如您所见,kafka_hosts 和 kafka_zookeeper_hosts 是列表。 这个剧本对我的服务器配置的结果是正确的:
/etc/kafka/consumer.properties:zookeeper.connect=opo-4:2181,opo-5:2181,opo-6:2181
/etc/kafka/producer.properties:metadata.broker.list=opo-1:9092,opo-2:9092,opo-3:9092
不幸的是,由于 DNS 问题,此配置不适用于我的所有服务器。我需要一个 IP 地址列表而不是主机名。
如果我在我的 playbook 中手动设置 IP 地址,我的配置有效,不幸的是不是动态的:
kafka_hosts:
- 192.168.48.1
- 192.168.48.2
- 192.168.48.3
kafka_zookeeper_hosts:
- 192.168.48.4
- 192.168.48.5
- 192.168.48.6
我的服务器上的结果使它 有效 :
/etc/kafka/consumer.properties:zookeeper.connect=192.168.48.4:2181,192.168.48.5:2181,192.168.48.6:2181
/etc/kafka/producer.properties:metadata.broker.list=192.168.48.1:9092,192.168.48.2:9092,192.168.48.3:9092
在此配置中,我必须使用相同的信息手动维护我的组 和 我的剧本。所以我想从 kafka 和 zookeeper.
组中获取 hostvars这里是 hostvars 和组,在主清单文件中定义:
[opo]
opo-1 ansible_host=192.168.48.1
opo-2 ansible_host=192.168.48.2
...
opo-6 ansible_host=192.168.48.6
[zookeeper]
opo-1
opo-2
opo-3
[kafka]
opo-4
opo-5
opo-6
我尝试过的 - 基于类似问题在 Whosebug 上找到的答案:
- kafka_hosts:“{{组[['kafka']['ansible_host']] |列表}}”
- kafka_hosts: "{{ [hostvars[groups['kafka'][0]]['ansible_host']] | list }}" #列表只包含第一个ip地址
- kafka_hosts:“{{ [hostvars[groups['kafka']]['ansible_host']] | list }}”
- kafka_hosts: "{{ hostvars[groups['kafka']].ansible_host | list }}"
- kafka_hosts: "{{ [hostvars.[groups['kafka']].ansible_host] | list }}"
- kafka_hosts:“{{组['kafka'].ansible_host |列表}}”
None 给出了预期的 IP 地址列表。
您需要使用extract
and map
combination:
kafka_hosts: "{{ groups['kafka'] | map('extract',hostvars,'ansible_host') | list }}"