IT评测·应用市场-qidao123.com

标题: 从混沌到秩序:Python的依赖管理工具分析 [打印本页]

作者: 魏晓东    时间: 2024-12-19 15:20
标题: 从混沌到秩序:Python的依赖管理工具分析
Python 的依赖管理工具不停没有标准化,原因主要包括:
1. 什么是依赖管理

依赖管理工具常用于处置处罚软件项目中的依赖关系。
在软件开发过程中,一个项目往往会依赖于许多其他的软件库、框架或组件。
依赖管理工具可以或许帮助开发者精确地指定这些依赖项的版本,主动下载和安装它们,并且可以在不同的环境中(如开发、测试、生产环境)包管依赖项的一致性。
如许可以有效制止因依赖版本杂乱而导致的软件故障、兼容性问题等环境。
比如,其他编程语言的标准依赖管理工具有:NodeJS的npm,Rust的cargo,Java的Maven等等。
依赖管理工具最关键的作用是可重复性,意味着我们可以遵循一系列步调,最终得到的软件项目是完全相同的。
特殊是现在的项目(不管是开源的还是内部的)基本都需要多人协作,确保每个人的代码编译出来的软件运行效果一致是至关重要的。
良好的依赖管理可以对开发构建部署阶段的全部依赖关系都明确声明,并与版本控制中的代码一起跟踪。
简单来说:应用步伐=代码+全部依赖项
具体可以归纳为以下几个步调:
2. 依赖管理工具对比

Python 的依赖管理工具固然没有统一,但是有很多可供选择,下面一一分析每个工具的优缺点。
2.1. pip

pip是自带的默认包管理器,也是使用最多的工具,它的特点是只能用来安装Python包。
优势
不足之处
2.2. venv

用于创建虚拟环境的内置工具,在虚拟环境中可使用 pip 安装包,通过设置环境变量来隔离环境。
优势:自Python 3.3起包罗在Python中。
不足之处
2.3. virtualenv

在 venv 成为 Python 内置工具前,我们通常使用virtualenv创建虚拟环境,可指定不同的 Python 表明器创建虚拟环境,需通过 pip 安装。
优势:能指定不同 Python 表明器创建虚拟环境。
不足之处与venv 是一样的。
2.4. pip-tools

轻量级工具,引入锁文件机制。
需先编写requirements.in作为定义文件,再用pip-compile天生requirements.txt锁文件,同步环境是使用pip-sync。
优势:轻量、简单,与基本的 pip/venv 工具协同工作。
不足之处
2.5. Pipenv

整合了 pip、virtualenv 和 pip-tools 的功能,通过Pipfile和Pipfile.lock管理依赖和虚拟环境,主动更新文件。
优势:轻量、简单,包装了基本的 pip/venv 工具。
不足之处
2.6. Poetry

旨在涵盖 Python 项目整个开发流程,包括项目引导、虚拟环境、依赖管理、构建和发布包。
通过pyproject.toml管理依赖,主动维护poetry.lock,支持依赖分组。
优势
不足之处
2.7. PDM

雷同于 Poetry,但遵循 PEP 标准,可使用uv进行依赖解析和安装,其构建后端可独立使用。
uv是后面将要介绍的另一个依赖管理工具。
优势
不足之处:与 Poetry 雷同,是 Python 工具,有较多依赖,存在相关缺点。
2.8. pyenv

用于安装和管理不同版本的 Python,可在全局或项目级别激活指定版本,是简单的 shell 实用步伐,不依赖 Python 安装。
优势
不足之处
2.9. pipx

将 pip 包安装在用户级别的独立虚拟环境中,制止依赖冲突,通过 symlink(软链接) 将入口点链接到PATH,方便调用。
优势:比直接在用户级别 pip 安装工具更好,能隔离依赖,可使用不同 Python 表明器。
不足之处
2.10. uv

用 Rust 编写的全能工具,旨在替代多个 Python 管理工具,处置处罚整个开发流程,包括安装包、管理虚拟环境、构建和发布等。
遵循 Python 标准,依赖定义在pyproject.toml,锁文件为uv.lock,支持任意依赖分组,能安装 pip 包作为可执行文件,可管理 Python 版本,维护全局包缓存。
优势
不足之处
2.11. Conda

由 Anaconda 公司开发的不同生态系统的包管理器,主要用于安装anaconda.org上的包,
能创建虚拟环境,与 pip 生态系统不同,对【】 的定义更广泛,包括共享库、头文件、可执行文件等。
优势
不足之处
2.12. Mamba

是Conda的改进版,旨在解决Conda的痛点,如慢的依赖解析和并行下载问题,用 C++ 实现,使用不同算法,推荐安装方式已改变。
速度比Conda 快很多,其他方面和Conda雷同。
2.13. Pixi

雷同于 uv,但针对 Conda 生态系统,用 Rust 编写,支持多平台。
通过pyproject.toml或pixi.toml设置,有方便的下令行界面,支持管理多个虚拟环境和定义文件,有锁文件机制,支持雷同 Makefile 的项目主动化任务,可指定系统依赖,但不帮助构建包。
优势
不足之处:与其他工具兼容性有限,且没有遵循 Conda 的全局环境理念。
3. 工具选择建议

如此之多的依赖管理工具,我们应该如何选择呢?
如果我们的项目只有对Python包的依赖,那么推荐uv和Pixi;
如果需要维护多个互斥的环境,那么推荐pip + venv + pip-tools + pyenv;
如果需处置处罚无法通过 pip 安装的依赖,那么建议使用Pixi。
4. 总结

Python的依赖管理工具很多,但是大部分工具其实大同小异,只是互相做了一些小的改进。
我们选择时,除了考虑遗留项目的问题之外,只管优先选择新出的工具。
新的工具除了会改进原有工具的缺点,还会借鉴其他语言的优秀的依赖管理工具。
现在,我个人的话,使用uv来管理项目比较多。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4