目前,当我们使用封隔器在AWS中创建AMI时,我们从/vars/var_<linux-os>.yml文件中读取检测到的OS的变量
示例
- name: read variables for ubuntu 20.04
include_vars: "vars_os_ubuntu-20.yml"
when: ansible_distribution == "Ubuntu" and ansible_distribution_version == "20.04"正如您在上面的代码中所看到的,我们已经特别提到了Ubuntu版本,现在,如果版本更改为22.04或者假设为24.04,我们如何动态地设置这个值?
我们有什么方法可以在Ansible中实现同样的功能吗?
发布于 2022-07-12 18:37:44
可以在include_vars中使用变量。
- name: >-
Include variables for {{ ansible_distribution }}
{{ ansible_distribution_version }}
include_vars: >-
vars_os_{{ ansible_distribution | lower }}-
{{- ansible_distribution_version.split('.')[0] }}.yml在我的阿尔卑斯容器中,这将给我在详细模式下运行剧本时-所以,使用-v标志:
TASK [Include variables for Alpine 3.15.4] ***********************************
ok: [localhost] => changed=false
ansible_facts: {}
ansible_included_var_files:
- /usr/local/ansible/vars_os_alpine-3.yml因此,正如详细消息所述,包含vars_os_alpin-3.yml文件,它与您的需求中的模式相匹配。
https://stackoverflow.com/questions/72956524
复制相似问题