如何部署使用uv管理依赖的python项目 ?

uv 当我从pip 包管理转向uv,就好像从一辆"五菱宏光"转向小米SU7. uv

核心前提:先了解 uv 的依赖管理逻辑

  • uv是基于 PEP 621 标准的现代包管理器,核心依赖文件是:
  • pyproject.toml:定义项目依赖、版本、入口等(替代传统的requirements.txt);
  • uv.lock:依赖锁文件(记录精确的依赖版本,确保部署环境和开发环境完全一致,类似package-lock.json)。
  • 部署的核心是:通过 uv 还原uv.lock中的依赖,而非手动安装,这是保证环境一致性的关键。

(1)创建虚拟环境

bash 复制代码
# 1. 创建虚拟环境(默认生成.venv文件夹)
uv venv

# 2. 激活虚拟环境(关键!必须激活后再装依赖)
.venv\Scripts\activate

(2)还原项目依赖

当我想要运行一个uv管理的python项目时,首先确保项目存在pyproject.toml, uv.lock. 这些是项目的依赖,包含精确的信息。我们可以直接使用以下命令:

bash 复制代码
# 生产环境:还原依赖(自动读取pyproject.toml和uv.lock)
uv pip install .

# 解释:
# .:表示安装当前项目的依赖(读取pyproject.toml)
# 若首次初始化(无uv.lock),直接生成锁文件+安装依赖
# uv install

(3)运行项目

bash 复制代码
uv run -m api.main

这个仅是作为示例,读者可以根据自己项目的启动命令进行调整。

(4)uv其它命令

  • pyproject.toml,这是 uv 管理项目依赖的核心设计;
  • 锁文件独立:uv.lock 记录精确版本,pyproject.toml 记录版本约束,二者分工明确,uv 会自动维护一致性。

uv add uv install两者之间的区别:是否修改pyproject.toml,

uv install 临时安装依赖(仅装到虚拟环境) ❌ 不修改

  1. 临时测试某个包;
  2. 部署时还原已定义的依赖

关键区分

  • uv install 是 "临时安装"(不写配置)
  • uv add 是 "纳入项目依赖"(写配置)

(5)一致性校验

  • uv sync --dry-run

Would uninstall 58 packages:这是 uv 的 "一致性校验" 行为 ------ 它只认 pyproject.toml + uv.lock 中记录的依赖,虚拟环境中额外安装的包会被判定为 "多余"。幸运的是 --dry-run 只是模拟操作,并没有真的卸载,给了你补救的机会。

相关推荐
AI人工智能+电脑小能手1 分钟前
【大白话说Java面试题】【Java基础篇】第26题:Java的抽象类和接口有哪些区别
java·开发语言·面试
曲幽4 分钟前
FastAPI 少有人提的实用技巧:把 Depends 依赖提到路由层,代码少写60%
python·fastapi·web·routes·depends·prefix·apiroute
qiaozhangchi8 分钟前
求解器学习笔记
笔记·python·学习
bzmK1DTbd10 分钟前
SOLID原则在Java中的实践:单一职责与开闭原则
java·开发语言·开闭原则
AI进化营-智能译站13 分钟前
ROS2 C++开发系列07-高效构建机器人决策逻辑,运算符与控制流实战
开发语言·c++·ai·机器人
winner888115 分钟前
C++ 命名空间、虚函数、抽象类、protected 权限全套通俗易懂精讲(附与 Java 对比)
java·开发语言·c++
不会编程的懒洋洋25 分钟前
C# P/Invoke 基础
开发语言·c++·笔记·安全·机器学习·c#·p/invoke
直奔標竿25 分钟前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring
时空系32 分钟前
认识Rust——我的第一个程序 Rust中文编程
开发语言·后端·rust
yqcoder34 分钟前
JavaScript 柯里化:把“大餐”拆成“小炒”的艺术
开发语言·javascript·ecmascript