1. Poetry and Cython
Poetry是一个 Python 的包和依赖管理工具, 使用 Poetry 开发一个PyPi包是非常快速的:
- poetry cli 可以快速一个 python 项目脚手架
- poetry 可以分别管理开发依赖和包依赖
- poetry 打包发布也很简单
Cython 是针对 Python 编程语言和扩展的 Cython 编程语言(基于 Pyrex)的优化静态编译器。它使为 Python 编写 C 扩展就像 Python 本身一样简单.
本文的重点不是介绍 poetry 和 cython 如何使用, 在本文中大致认为 poetry 是一种打包工具, 而 cython 是一种编译工具, 使用 cython 将敏感代码编译为.so 文件然后使用 poetry 打包这些.so 文件为一个 wheel 包可以用 pip 进行安装.
2. 集成 Poetry 和 Cython
2.1 代码文件
假设我们的代码结构如下;
1 | . |
object_storage 文件夹存放的项目或者包的源码, poetry 的配置文件也在根目录, 这个结构也是 poetry 自动生成的脚手架代码, 其中 object_storage 是创建项目是提供的名称.
2.2 Cython 编译
cython 编译没有想象中复杂, 这里的编译代码和技巧也是从官方文档的快速上手文档中了解的. 在根目录创建一个 build.py 文件, 内容如下:
1 | from Cython.Build import cythonize |
Tip
其实如果不想和 poetry 集成, 只需要将将文件名称修改为 setup.py, 然后就可以通过 pip intall git+https 的方案是安装了
2.3 Poetry 集成
增加编译依赖
修改 pyproject.toml 修改 build-system 内容如下:
1 | [build-system] |
其中主要增加: Cython 和 setuptools 两个构建依赖
自定义 Poetry 构建
修改 pyproject.toml 修改 tool.poetry.build 内容如下:
1 | [tool.poetry.build] |
这里主要是让 poetry 构建的时候使用自定义的脚本, 因为要本地测试做在开发依赖中需要安装: cython/setuptools/wheel
Poetry 打包
修改 pyproject.toml 修改 tool.poetry 内容如下:
1 | [tool.poetry] |
这里主要增加: include 和 exclude, 作用是排除.py 源码文件仅保留.so, 为什么这么做和本文的主题有关, 本文的主题是构建一个源码被保护的 python 包
2.4 测试和使用
本文中的代码已经开源到 github, 这里直接使用 git+https 的方式进行安装和测试
安装
1 | (env) ➜ pythontest pip install git+https://github.com/nnsay/object_storage.git@cython |
测试
测试脚本与包的发布包的代码相关, 我的包是一个针对不同对象存储厂商服务的抽象包, 所以这里测试一下是不是可以调用生成 signedURL 即可.
1 | (env) ➜ pythontest python testoos.py |
Note
请问忽略测试结果输出, 理论上只要可以调用成功, 就证明.so 的 python 包安装成功了
3. 总结
本文从简单介绍了 cython 和 poetry 对的集成, 但是更具有核心价值的是: 利用 cython 将代码 python 代码编译, 然后结合使用 poetry 将包发布和安装. 如果结合 docker, 该方式可以交付编译后的代码制品, 更好的保护源码.