2. 在类Unix环境下使用Python

2.1. 获得并安装Python的最新版本

2.1.1. 在Linux中

Python预装在大多数Linux发行版上,并作为一个包提供给所有其他用户。 但是,您可能想要使用的某些功能在发行版提供的软件包中不可用。这时您可以从源代码轻松编译最新版本的Python。

如果Python没有预先安装并且不在发行版提供的库中,您可以轻松地为自己使用的发行版创建包。 参阅以下链接:

参见

https://www.debian.org/doc/manuals/maint-guide/first.en.html

对于Debian用户

https://en.opensuse.org/Portal:Packaging

对于OpenSuse用户

https://docs-old.fedoraproject.org/en-US/Fedora_Draft_Documentation/0.1/html/RPM_Guide/ch-creating-rpms.html

对于Fedora用户

http://www.slackbook.org/html/package-management-making-packages.html

对于Slackware用户

2.1.2. 在FreeBSD和OpenBSD上

  • FreeBSD用户,使用以下命令添加包:

    1. pkg install python3
  • OpenBSD用户,使用以下命令添加包:

    1. pkg_add -r python
    2. pkg_add ftp://ftp.openbsd.org/pub/OpenBSD/4.2/packages/<insert your architecture here>/python-<version>.tgz

    例如:i386用户获取Python 2.5.1的可用版本:

    1. pkg_add ftp://ftp.openbsd.org/pub/OpenBSD/4.2/packages/i386/python-2.5.1p2.tgz

2.1.3. 在OpenSolaris系统上

你可以从 OpenCSW 获取、安装及使用各种版本的Python。比如 pkgutil -i python27

2.2. 构建Python

如果你想自己编译CPython,首先要做的是获取 source 。您可以下载最新版本的源代码,也可以直接提取最新的 clone 。 (如果你想要制作补丁,则需要克隆代码。)

构建过程由常用命令组成:

  1. ./configure
  2. make
  3. make install

特定 Unix 平台的 配置选项 和注意事项通常会详细地记录在 Python 源代码树的根目录下的 README.rst 文件中。

警告

make install 可以覆盖或伪装 python3 二进制文件。因此,建议使用 make altinstall 而不是 make install ,因为后者只安装了 *exec_prefix*/bin/python*version*

2.3. 与Python相关的路径和文件

这取决于本地安装惯例; prefix${prefix} )和 exec_prefix${exec_prefix} ) 取决于安装,应解释为GNU软件;它们可能相同。

例如,在大多数Linux系统上,两者的默认值是 /usr

文件/目录

含意

exec_prefix/bin/python3

解释器的推荐位置

prefix/lib/pythonversion, exec_prefix/lib/pythonversion

包含标准模块的目录的推荐位置

prefix/include/pythonversion, exec_prefix/include/pythonversion

包含开发Python扩展和嵌入解释器所需的include文件的目录的推荐位置

2.4. 杂项

要在Unix上使用Python脚本,需要添加可执行权限,例如:

  1. $ chmod +x script

并在脚本的顶部放置一个合适的Shebang线。一个很好的选择通常是:

  1. #!/usr/bin/env python3

将在整个 PATH 中搜索Python解释器。但是,某些Unix系统可能没有 env 命令,因此可能需要将 /usr/bin/python3 硬编码为解释器路径。

要在Python脚本中使用shell命令,请查看 subprocess 模块。

2.5. 自定义 OpenSSL

  1. 要使用发行商的 OpenSSL 配置和系统信任存储库,请找到包含 openssl.cnf 文件或符号链接的目录,它位于 /etc 中。 在大多数发行版上该文件是在 /etc/ssl 或者 /etc/pki/tls 中。 该目录还应当包含一个 cert.pem 文件和/或一个 certs 目录。

    1. $ find /etc/ -name openssl.cnf -printf "%h\n"
    2. /etc/ssl
  2. 下载、编译并安装 OpenSSL。 请确保你使用 install_sw 而不是 installinstall_sw 的目标不会覆盖 openssl.cnf

    1. $ curl -O https://www.openssl.org/source/openssl-VERSION.tar.gz
    2. $ tar xzf openssl-VERSION
    3. $ pushd openssl-VERSION
    4. $ ./config \
    5. --prefix=/usr/local/custom-openssl \
    6. --libdir=lib \
    7. --openssldir=/etc/ssl
    8. $ make -j1 depend
    9. $ make -j8
    10. $ make install_sw
    11. $ popd
  3. 使用自定义 OpenSSL 编译 Python(参见配置 --with-openssl 和 --with-openssl-rpath 选项)

    1. $ pushd python-3.x.x
    2. $ ./configure -C \
    3. --with-openssl=/usr/local/custom-openssl \
    4. --with-openssl-rpath=auto \
    5. --prefix=/usr/local/python-3.x.x
    6. $ make -j8
    7. $ make altinstall

注解

OpenSSL 的补丁发布版具有向下兼容的 ABI。 你不需要重新编译 Python 来更新 OpenSSL。 使用一个新的版本来替代自定义 OpenSSL 安装版就可以了。