Python 3 支持

Ansible 2.5 及以上版本支持 Python 3。在 2.5 之前,使用 Python 3 被认为是技术预览。本主题讨论如何设置您的控制节点和受管机器以使用 Python 3。

请参阅 控制节点要求受管节点要求 以了解支持的具体版本。

在控制节点端

在 Python 3 下运行 /usr/bin/ansible 最简单的方法是使用 Python3 版本的 pip 安装它。这将使默认的 /usr/bin/ansible 使用 Python3 运行。

$ pip3 install ansible
$ ansible --version | grep "python version"
  python version = 3.10.5 (main, Jun 9 2022, 00:00:00) [GCC 12.1.1 20220507 (Red Hat 12.1.1-1)] (/usr/bin/python)

如果您正在运行 Ansible 从克隆运行开发分支 并希望使用 Python 3 与您的源代码检出,请通过 python3 运行您的命令。例如

$ source ./hacking/env-setup
$ python3 $(which ansible) localhost -m ping
$ python3 $(which ansible-playbook) sample-playbook.yml

注意

各个 Linux 发行版的软件包可能打包为 Python2 或 Python3。当从发行版软件包运行时,您将只能使用 Ansible 与其安装的 Python 版本一起使用。有时,发行版会提供安装多个 Python 版本的方法(通过单独的软件包或通过安装后运行的一些命令)。您需要检查您的发行版以查看这是否适用于您的情况。

使用命令和 playbook 在受管机器上使用 Python 3

  • Ansible 将自动检测并在许多随附 Python 3 的平台上使用它。要显式配置 Python 3 解释器,请在组或主机级别将 ansible_python_interpreter 清单变量设置为 Python 3 解释器的位置,例如 /usr/bin/python3。默认解释器路径也可以在 ansible.cfg 中设置。

另请参阅

解释器发现 以获取更多信息。

# Example inventory that makes an alias for localhost that uses Python3
localhost-py3 ansible_host=localhost ansible_connection=local ansible_python_interpreter=/usr/bin/python3

# Example of setting a group of hosts to use Python3
[py3_hosts]
ubuntu16
fedora27

[py3_hosts:vars]
ansible_python_interpreter=/usr/bin/python3

另请参阅

如何构建您的清单 以获取更多信息。

  • 运行您的命令或 playbook

$ ansible localhost-py3 -m ping
$ ansible-playbook sample-playbook.yml

请注意,您还可以使用 -e 命令行选项在运行命令时手动设置 python 解释器。如果您想测试特定模块或 playbook 在 Python 3 下是否存在任何错误,这将非常有用。例如

$ ansible localhost -m ping -e 'ansible_python_interpreter=/usr/bin/python3'
$ ansible-playbook sample-playbook.yml -e 'ansible_python_interpreter=/usr/bin/python3'

如果发现不兼容性该怎么办

我们在几个版本中花费了大量时间修复错误并添加新的测试,以便 Ansible 的核心功能集可以在 Python 2 和 Python 3 下运行。但是,在极端情况下仍然可能存在错误,并且许多与 Ansible 一起提供的模块由社区维护,并且并非所有这些模块都可能已被移植。

如果您在 Python 3 下发现错误,您可以在 Ansible 的 GitHub 项目 上提交错误报告。请务必在错误报告中提及 Python3,以便相关人员查看。

如果您想修复代码并在 github 上提交拉取请求,您可以参考 Ansible 和 Python 3 以了解我们如何在 Ansible 代码库中修复常见的 Python3 兼容性问题。