Ansible-core 2.14 移植指南
本节讨论 ansible-core
2.13 和 ansible-core
2.14 之间的行为变化。
旨在帮助您更新您的 Playbook、插件和 Ansible 基础设施的其他部分,以便它们可以在此版本的 Ansible 上工作。
我们建议您阅读此页面以及 ansible-core 2.14 的变更日志,以了解您可能需要进行的更新。
本文档是移植系列文档的一部分。完整的移植指南列表可以在 移植指南 中找到。
Playbook
条件 - 由于在 ansible-core 2.14.12 中缓解了安全问题 CVE-2023-5764,带有嵌入式模板块的条件表达式可能会失败,并显示消息 “
Conditional is marked as unsafe, and cannot be evaluated.
” 当嵌入式模板查询来自不受信任的源(如模块结果或标记为!unsafe
的变量)的数据时。当引用不受信任的数据时,带有嵌入式模板的条件可能是恶意模板注入的来源,并且几乎总是可以在没有嵌入式模板的情况下重写。Playbook 任务条件关键字(如when
和until
)长期以来一直显示警告,不鼓励在条件中使用嵌入式模板;此警告也已扩展到非任务条件,例如assert
操作。- name: task with a module result (always untrusted by Ansible) shell: echo "hi mom" register: untrusted_result # don't do it this way... # - name: insecure conditional with embedded template consulting untrusted data # assert: # that: '"hi mom" is in {{ untrusted_result.stdout }}' - name: securely access untrusted values directly as Jinja variables instead assert: that: '"hi mom" is in untrusted_result.stdout'
现在变量是延迟求值的;只有在实际使用时才求值。例如,在 ansible-core 2.14 中,表达式
{{ defined_variable or undefined_variable }}
如果or
的第一部分被求值为True
,则不会因为undefined_variable
而失败,因为它不需要计算第二部分。一个特别需要注意的行为变化是以下任务,该任务使用了undefined
测试。在 2.14 版本之前,这将导致尝试访问字典中未定义的值时出现致命错误。在 2.14 中,断言通过,因为字典通过其未定义的值之一被评估为未定义。
- assert: that: - some_defined_dict_with_undefined_values is undefined vars: dict_value: 1 some_defined_dict_with_undefined_values: key1: value1 key2: '{{ dict_value }}' key3: '{{ undefined_dict_value }}'
命令行
控制器节点上的 Python 3.9 是此版本的硬性要求。
在启动时,会检查文件系统编码和区域设置以验证它们是否为 UTF-8。如果不是,进程将退出并显示报告错误编码的错误。如果您之前使用的是
C
或POSIX
区域设置,您可以使用C.UTF-8
。如果您之前使用的是诸如en_US.ISO-8859-1
之类的区域设置,则可以使用en_US.UTF-8
。为简单起见,使用LC_ALL
环境变量导出适当的区域设置可能是最简单的方法。修改系统区域设置的另一种方法是在 UTF-8 模式下运行 Python;有关详细信息,请参阅 Python 文档。
已弃用
没有值得注意的更改
模块
没有值得注意的更改
已移除的模块
以下模块不再存在
没有值得注意的更改
弃用通知
没有值得注意的更改
值得注意的模块更改
没有值得注意的更改
插件
没有值得注意的更改
移植自定义脚本
没有值得注意的更改
网络
没有值得注意的更改