在 GitLab CI/CD 中使用 uv
使用 uv 镜像
Astral 提供了预装 uv 的 Docker 镜像。请选择适合您工作流的变体。
.gitlab-ci.yml
variables:
UV_VERSION: "0.10.9"
PYTHON_VERSION: "3.12"
BASE_LAYER: trixie-slim
# GitLab CI creates a separate mountpoint for the build directory,
# so we need to copy instead of using hard links.
UV_LINK_MODE: copy
uv:
image: ghcr.io/astral-sh/uv:$UV_VERSION-python$PYTHON_VERSION-$BASE_LAYER
script:
# your `uv` commands
注意
如果您使用的是 distroless(无发行版)镜像,则必须指定入口点 (entrypoint)。
缓存
在工作流运行之间持久化 uv 缓存可以提高性能。
uv-install:
variables:
UV_CACHE_DIR: .uv-cache
cache:
- key:
files:
- uv.lock
paths:
- $UV_CACHE_DIR
script:
# Your `uv` commands
after_script:
- uv cache prune --ci
有关配置缓存的更多详细信息,请参阅 GitLab 缓存文档。
建议在作业结束时使用 uv cache prune --ci 来减小缓存大小。有关更多详细信息,请参阅 uv 缓存文档。
使用 uv pip
如果您使用 uv pip 接口而不是 uv 项目接口,uv 默认要求使用虚拟环境。要允许将包安装到系统环境中,请在所有 uv 调用中使用 --system 标志,或设置 UV_SYSTEM_PYTHON 变量。
UV_SYSTEM_PYTHON 变量可以在不同的作用域中定义。您可以在此处阅读有关 GitLab 变量及其优先级如何工作的更多信息。
通过在顶层定义它,可以为整个工作流选择启用(该选项)。
若要再次选择禁用,可以在任何 uv 调用中使用 --no-system 标志。
持久化缓存时,您可能希望使用 requirements.txt 或 pyproject.toml 作为缓存键文件,而不是 uv.lock。