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.cfgdefaults 部分设置 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 可以通过 ansible.cfgdefaults 部分的 run_vars_pluginsANSIBLE_RUN_VARS_PLUGINS 环境变量进行设置。默认选项 demand 会在任务需要变量时运行与清单源相关的任何已启用的 vars 插件。您可以使用选项 start,在导入该清单源后运行与清单源相关的任何已启用的 vars 插件。

您还可以针对支持 stage 选项的 vars 插件,在每个插件的基础上控制 vars 插件的执行。要导入清单后运行 host_group_vars 插件,您可以将以下内容添加到 ansible.cfg

[vars_host_group_vars]
stage = inventory

插件列表

您可以使用 ansible-doc -t vars -l 查看可用的 vars 插件列表。使用 ansible-doc -t vars <plugin name> 查看特定插件的文档和示例。

另请参阅

缓存插件

缓存插件

查找插件

查找插件

沟通

有问题?需要帮助?想分享你的想法?请访问 Ansible 沟通指南