Vars 插件
Vars 插件将额外的变量数据注入到 Ansible 运行中,这些数据并非来自清单源、playbook 或命令行。像 ‘host_vars’ 和 ‘group_vars’ 这样的 playbook 结构使用 vars 插件工作。有关 Ansible 中变量的更多详细信息,请参阅 使用变量。
Vars 插件在 Ansible 2.0 中部分实现,并在 Ansible 2.4 开始被重写以完全实现。
Ansible 附带的 host_group_vars 插件支持读取 为一台机器分配变量:主机变量 和 为多台机器分配变量:组变量 中的变量。
启用 Vars 插件
您可以通过将自定义 vars 插件放入 playbook 旁边的 vars_plugins
目录、角色内部,或将其放入 ansible.cfg 中配置的目录源之一来激活它。为了使 vars 插件在清单构建期间运行,您不能在 playbook 或角色中启用它,因为这些内容直到稍后才会加载。如果它们仅在任务执行时运行,则对提供它们的位置没有限制。
大多数 vars 插件默认情况下是禁用的。要启用 vars 插件,请在 ansible.cfg 的 defaults
部分设置 vars_plugins_enabled
,或将 ANSIBLE_VARS_ENABLED
环境变量设置为要执行的 vars 插件列表。默认情况下,Ansible 附带的 host_group_vars 插件是启用的。
从 Ansible 2.10 开始,您可以在集合中使用 vars 插件。集合中的所有 vars 插件都必须显式启用,并且必须使用格式为 namespace.collection_name.vars_plugin_name
的完全限定集合名称。
[defaults]
vars_plugins_enabled = host_group_vars,namespace.collection_name.vars_plugin_name
使用 Vars 插件
默认情况下,在启用 vars 插件后,它们会根据需要自动使用。
从 Ansible 2.10 开始,可以使 vars 插件在特定时间运行。ansible-inventory 不使用这些设置,并且始终加载 vars 插件。
全局设置 RUN_VARS_PLUGINS
可以通过 defaults
部分中的 run_vars_plugins
在 ansible.cfg
中设置,也可以通过 ANSIBLE_RUN_VARS_PLUGINS
环境变量设置。默认选项 demand
会在任务需要变量时运行与清单源相关的任何已启用的 vars 插件。您可以使用选项 start
来代替,它会在导入清单源后运行与清单源相关的任何已启用的 vars 插件。
您还可以针对支持 stage
选项的 vars 插件,控制每个插件的执行。要使 host_group_vars 插件在导入清单后运行,您可以将以下内容添加到 ansible.cfg
[vars_host_group_vars]
stage = inventory
插件列表
您可以使用 ansible-doc -t vars -l
查看可用 vars 插件的列表。使用 ansible-doc -t vars <plugin name>
查看特定插件的文档和示例。