【发布时间】:2019-11-21 00:50:08
【问题描述】:
下面是一个“工作”版本,我在我的库存文件中定义了配置: 库存文件:
all:
children:
grp1:
hosts:
host1:
grp2:
children:
subgrp1:
vars:
config_vars:
name1: "value1"
name2: "value2"
hosts:
host11:
host12:
subgrp2:
vars:
config_vars:
name1: "value3"
name2: "value4"
hosts:
host21:
host22:
grp3:
hosts:
host31:
host32:
我的剧本看起来像:
---
- name: test play
hosts: grp2
connection: ssh
gather_facts: no
remote_user: ec2-user
tasks:
- debug:
msg: "inventory_hostname = {{ inventory_hostname}} and item.key = {{ item.key }} and value = {{ item.value }} "
when: "{{ item['key'] }} == config_vars "
loop: "{{ lookup('dict', hostvars[inventory_hostname]) }}"
在运行ansible-playbook -i hosts.yml p1.yml 时,我有:
ok: [host22] => (item={'key': 'config_vars', 'value': {'name1': 'value3', 'name2': 'value4'}}) => {
...
ok: [host21] => (item={'key': 'config_vars', 'value': {'name1': 'value3', 'name2': 'value4'}}) => {
...
ok: [host11] => (item={'key': 'config_vars', 'value': {'name1': 'value1', 'name2': 'value2'}}) => {
...
ok: [host12] => (item={'key': 'config_vars', 'value': {'name1': 'value1', 'name2': 'value2'}}) => {
(查看 name1 和 name2 的值如何根据每个组的配置对齐)
我拥有的“非工作”配置是,我从清单文件中删除 config_vars,取而代之的是一个与 hosts.yml 结构匹配的目录结构,并将 config_vars 字典粘贴在每个组的目录下
> cat group_vars/grp2/subgrp2/main.yml
config_vars:
name1: "value3"
name2: "value4"
> cat group_vars/grp2/subgrp1/main.yml
config_vars:
name1: "value1"
name2: "value2"
然后我像以前一样重新运行命令,我看到了:
ok: [host22] => (item={'key': 'config_vars', 'value': {'name1': 'value3', 'name2': 'value4'}}) => {
ok: [host12] => (item={'key': 'config_vars', 'value': {'name1': 'value3', 'name2': 'value4'}}) => {
ok: [host21] => (item={'key': 'config_vars', 'value': {'name1': 'value3', 'name2': 'value4'}}) => {
ok: [host11] => (item={'key': 'config_vars', 'value': {'name1': 'value3', 'name2': 'value4'}}) => {
(value1 和 value2 被破坏)
我有点知道为什么会这样;这是因为 value3 和 value4 是稍后读取的,所以它们替换了 value 1 和 value2。我的问题是:当我像这样构造变量组织时,如何保留组与配置的绑定。 如果我以其他任何方式进行操作也可以,但将变量从库存文件中取出。非常感谢提前
【问题讨论】: