如何为 Linux 打包 Python 应用
了解如何使用 dh_virtualenv 来让你的 Python 应用可作为 .deb 包安装。
在基于 Debian 的操作系统(例如 Debian 或 Elementary OS)上安装 Python 应用的一种方法是使用 dh_virtualenv 工具。它可以构建一个 .deb
包,在应用之外封装了一个 Python 虚拟环境,并在安装时进行部署。
在本文中,我将以构建一个包含 HTTPie 工具的包为例来解释如何使用它,以便在无需激活虚拟环境的情况下从命令行测试 HTTP API。
使用 dh_virtualenv 打包
首先,你需要安装 dh_virtualenv
所需的工具。dh_virtualenv
的文档提供了所有安装选项。在基于 Debian 的系统上,我输入:
1 |
|
尽管不需要 devscripts 包,但它可以简化后续操作。
现在,创建一个目录来保存源码。由于这是一个本地的、非官方的 HTTPie 打包,因此我将其称为 myhttp
。接下来,让我们在 myhttp
内创建一些文件,向 Debian 构建系统提供元数据。
首先,创建 debian/control
文件:
1 |
|
那么这些是什么信息呢?正如 Debian 文档指出的:
“第 1–7 行是源码包的控制信息。第 9–13 行是二进制包的控制信息。”
以下是我使用的:
Section
的值对于我们来说大多没有意义,但需要存在。它对给引导式 UI 安装程序提供信息是有意义的,但对于这个包来说,没有意义。Priority
对像这样的第三方包的正确值是extra
。- 强烈建议在
Maintainer
字段中填写正确的联系人信息。但不一定非得是你的个人电子邮件,如果包由团队维护,并且你希望将问题发送到团队的邮件别名,例如Infrastructure Team <infra-team-list@company.example.com>
。 Build-Depends
字段标识你需要debhelper
、python
和dh-virtualenv
来构建包:包构建过程中将确保这些依赖项在包构建时已安装。Standards-Version
字段主要给人看。它表明你遵循的指南。本指南基于dh-virtualenv
的官方文档,它是基于 Debian 的 3.9.5 指南。最好一直将源码包和二进制包命名相同。Architecture
字段应为Any
,因为除非虚拟环境可能包含一些特定于体系结构的文件。否则,最好选择该字段为any
。- 保持
Pre-Depends
列表不变:它是一种非常严格的依赖关系形式,你很少会需要比这里建议的最小依赖更多的依赖项。依赖项通常由构建系统准确计算,因此没有理由手动指定它们。 - 如果你的包主要用于内部,那么
Description
字段可能只需要最少的信息或者指向公司 wiki 的链接,不然更多的信息会更有用。
然后创建 debian/compat
文件,它主要出于历史目的而存在:
1 |
|
接下来,创建更新日志以告知包用户自上次发布以来发生了什么变化。最简单的方法是使用 dch --create
创建模板,然后填写值。
填写后,它看起来像:
1 |
|
现在你需要告诉工具安装 HTTPie,但是哪个版本?
创建一个宽松版本的 requirements.in
文件:
1 |
|
通常,宽松的需求文件将仅包含项目的直接依赖项,并在需要时指定最低版本。不一定总是需要指定最低版本:这些工具通常偏向于将依赖关系转化为“可能的最新版本”。如果你的 Debian 包与一个内部 Python 包相对应,这是内部应用中的一种常见情况,那么宽松的需求文件看起来将很相似:仅包含包名的一行。
然后使用 pip-compile
(可通过安装 PyPI 包 pip-tools
获得):
1 |
|
这会生成一个严格的依赖文件,名为 requirements.txt
:
1 |
|
最后,写一个 debian/rules
文件来创建包。因为 dh_virtualenv
会处理所有困难的事,因此规则文件很简单:
1 |
|
确保指定 Python 解释器。默认它会使用 /usr/bin/python
,这是 Python2,但是你应该使用一个受支持的 Python 版本。
完成了,接下来就是构建包:
1 |
|
这会在父目录生成一个类似 myhttp_2.0.0-1_amd64.deb
的文件。该文件可在任何兼容的系统上安装。
通常,最好在同一平台上构建用于特定平台(例如 Debian 10.0)的 Debian 包。
你可以将此 Debian 包保存在软件仓库中,并使用例如 Ansible 的工具将其安装在所有相关系统上。
总结
给基于 Debian 的系统的打包应用是一个有着多个步骤的过程。使用 dh_virtualenv
将使过程变得简单明了。
via: https://opensource.com/article/20/4/package-python-applications-linux
作者:Moshe Zadka 选题:lujun9972 译者:geekpi 校对:wxy