Ansible-core 2.12 移植指南
本节讨论 ansible-core 2.11 和 ansible-core 2.12 之间的行为变化。
旨在帮助您更新 Playbook、插件和其他 Ansible 基础设施部件,使其与此版本的 Ansible 兼容。
我们建议您阅读本页以及 ansible-core 2.12 更新日志,以了解您可能需要进行的更新。
本文档是关于移植的系列文档的一部分。完整的移植指南列表可以在 移植指南中找到。
Playbook
当调用任务并设置
async时,在environment:下设置ANSIBLE_ASYNC_DIR不再有效。请改用 shell 配置变量async_dir,例如通过设置ansible_async_dir。
tasks:
- dnf:
name: '*'
state: latest
async: 300
poll: 5
vars:
ansible_async_dir: /path/to/my/custom/dir
undef()函数已添加到模板环境中,用于在模板中直接创建未定义的变量。可以选择为旨在被覆盖的变量提供提示。
vars:
old: "{{ undef }}"
new: "{{ undef() }}"
new_with_hint: "{{ undef(hint='You must override this variable') }}"
Python 解释器发现
INTERPRETER_PYTHON 的默认值已更改为 auto。INTERPRETER_PYTHON_FALLBACK 中的 Python 解释器列表已更改为优先选择 Python 3 而不是 Python 2。这两个更改的结合意味着新的默认行为是在远程主机上静默地优先选择 Python 3 而不是 Python 2。以前,在解释器发现会使用 Python 3 但解释器设置为 /usr/bin/python 的情况下,会发出弃用警告。
可以通过设置 ansible_interpreter_python_fallback 变量来更改 INTERPRETER_PYTHON_FALLBACK 的默认解释器列表。
有关更多详细信息,请参阅 解释器发现文档。
命令行
控制器节点上的 Python 3.8 是此版本的硬性要求。命令行脚本将无法在较低的 Python 版本下运行。
ansible-vault不再支持PyCrypto,并且需要cryptography。
已弃用
此版本中,目标节点上的 Python 2.6 已被弃用。
ansible-core2.13 将删除对 Python 2.6 的支持。条件语句中的裸变量:
when条件语句不再自动将字符串布尔值(如"true"和"false")解析为实际的布尔值。任何包含非空字符串的变量都被认为是 true。之前可以通过CONDITIONAL_BARE_VARS配置选项(以及ANSIBLE_CONDITIONAL_BARE_VARS环境变量)进行配置。此设置不再有任何效果。用户可以通过使用|bool过滤器来解决此问题。
vars:
teardown: 'false'
tasks:
- include_tasks: teardown.yml
when: teardown | bool
- include_tasks: provision.yml
when: not teardown | bool
ActionBase中的_remote_checksum()方法已弃用。任何使用此方法的操作插件都应改用_execute_remote_stat()。
模块
cron现在要求在所有情况下都指定name。cron不再允许reboot参数。请改用special_time: reboot。hostname- 在 FreeBSD 上,如果永久主机名文件不存在,before结果将不再是"temporarystub"。为了与其他系统保持一致,它将是""(空字符串)。hostname- 在基于 OpenRC 和 Solaris 的系统上,如果永久主机名文件不存在,before结果将不再是"UNKNOWN"。为了与其他系统保持一致,它将是""(空字符串)。pip现在使用为 Ansible 模块的 Python 解释器安装的pipPython 模块(如果可用),除非指定了executable或virtualenv。
已移除的模块
以下模块不再存在
无重大更改
弃用通知
无重大更改
值得注意的模块更改
无重大更改
插件
Jinja2 < 2.10 的
unique过滤器是区分大小写的,如果case_sensitive=False而不是case_sensitive=True,现在会一致地引发错误。集合理论过滤器(
intersect、difference、symmetric_difference和union)现在是区分大小写的。显式使用case_sensitive=False以保持以前的行为。注意:在 Jinja2 < 2.10 中,这些过滤器默认是区分大小写的。当未指定选项时,
password_hash现在使用passlib默认值,例如bcrypt_sha256现在默认使用 “2b” 格式,如果需要 “2a” 格式,则必须指定。
移植自定义脚本
无重大更改
网络
无重大更改