Ansible-core 2.16 移植指南
本节讨论 ansible-core
2.15 和 ansible-core
2.16 之间的行为变化。
其目的是帮助您更新您的 playbook、插件以及 Ansible 基础架构的其他部分,以便它们能够与这个版本的 Ansible 兼容。
我们建议您阅读此页面以及 Ansible-core 2.16 版本变更日志,以了解您可能需要进行哪些更新。
本文档是移植集合的一部分。完整的移植指南列表可在 移植指南 中找到。
Playbook
条件语句 - 由于在 ansible-core 2.16.1 中缓解了安全问题 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'