在Ansible中,如果我尝试使用变量作为参数名或键名,则永远无法解析它。例如,如果我有{{ some_var }}: true,或者:

template: "{{ resolve_me_to_src }}": "some_src"

这些变量将仅按字面意义使用,而不会解析。我的特定用例是将它与ec2模块一起使用,其中一些标签名称存储为变量:
- name: Provision a set of instances
  ec2:
    group: "{{ aws_security_group }}"
    instance_type: "{{ aws_instance_type }}"
    image: "{{ aws_ami_id }}"
    region: "{{ aws_region }}"
    vpc_subnet_id: "{{ aws_vpc_subnet_id }}"
    key_name: "{{ aws_key_name }}"
    wait: true
    count: "{{ num_machines }}"
    instance_tags: { "{{ some_tag }}": "{{ some_value }}", "{{ other_tag }}": "{{ other_value }}" }

有没有办法解决?我可以标记我想以某种方式强制评估吗?

最佳答案

这对您有用吗?

(rc=0)$ cat training.yml
- hosts: localhost
  tags: so5
  gather_facts: False
  vars: [
      k1: 'key1',
      k2: 'key2',
      d1: "{
        '{{k1}}': 'value1',
        '{{k2}}': 'value2',
      }",
    ]
  tasks:
  - debug: msg="{{item}}"
    with_dict: "{{d1}}"


(rc=0)$ ansible-playbook training.yml -t so5

PLAY [localhost] ****************************************************************

PLAY [localhost] ****************************************************************

TASK: [debug msg="{{item}}"] **************************************************
ok: [localhost] => (item={'key': 'key2', 'value': 'value2'}) => {
    "item": {
        "key": "key2",
        "value": "value2"
    },
    "msg": "{'value': 'value2', 'key': 'key2'}"
}
ok: [localhost] => (item={'key': 'key1', 'value': 'value1'}) => {
    "item": {
        "key": "key1",
        "value": "value1"
    },
    "msg": "{'value': 'value1', 'key': 'key1'}"
}

PLAY RECAP ********************************************************************
localhost                    : ok=1    changed=0    unreachable=0    failed=0

(rc=0)$

技巧是用双引号包装dict声明。 Ansible将此未记录的(但一致的),translation脚的翻译(anible相当于shell变量expantion)应用于剧本中的大多数(并非全部)YAML值(':'的所有RHS)。这是一些组合,以未知顺序将这些字符串通过Jinja2引擎,Python解释器和ansible引擎。

关于ansible - 在Ansible中解析字典键或参数变量,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27805976/

10-14 13:29
查看更多