Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

UV Refactor with Docker CPU #944

Draft
wants to merge 2 commits into
base: main
Choose a base branch
from
Draft

UV Refactor with Docker CPU #944

wants to merge 2 commits into from

Conversation

alexnorell
Copy link
Contributor

@alexnorell alexnorell commented Jan 14, 2025

Key Changes

  • Migrated from setup.py to pyproject.toml for modern Python package management
  • Optimized Docker build process with multi-stage builds
  • Consolidated and updated dependency management
  • Removed redundant configuration files

Details

Package Management

  • Replaced setup.py with pyproject.toml for package configuration and dependency management
  • Introduced UV package manager for faster and more reliable dependency installation
  • Removed .isort.cfg and pytest.ini in favor of consolidated config in pyproject.toml

Docker Optimization

  • Optimized Dockerfile.onnx.cpu:
    • Switched to slim Python base image
    • Implemented multi-stage build to reduce final image size
    • Consolidated ENV variables
    • Updated to Python 3.13

Dependency Updates

  • Updated and standardized dependency versions across requirements files
  • Loosened version constraints on several packages while maintaining compatibility
  • Dependencies are now properly categorized in pyproject.toml under optional features

Technical Notes

  • Uses hatchling as the build backend
  • Maintains all existing optional dependencies but organizes them better
  • Dockerfile now uses UV for more efficient package installation

This change modernizes our Python package management approach and optimizes our container builds while maintaining all existing functionality.


Implementation Details
  • Replaced multiple requirements.txt files with pyproject.toml optional dependencies
  • Introduced multi-stage Docker build to optimize image size
  • Consolidated isort and pytest configurations into pyproject.toml
  • Updated dependency constraints to be more flexible while maintaining stability

pyproject.toml Outdated Show resolved Hide resolved
"torch>=2.0.1,<=2.4.0",
]

[project.optional-dependencies]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

are we duplicating these here and in the requirements.*.txt files? Is there a way to make sure we can keep them in sync or maybe we wouldnt need the requirement files anymore?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This removes the needs for requirements.txt. Didn't remove them yet since I'm not done with the migration of the dockerfiles.

@@ -1,3 +0,0 @@
[settings]
profile = black
skip = **/__init__.py, **/node_modules/**
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

are we confident this files should be removed?

FROM python:3.9 as base

# Builder stage
FROM python:3.13-slim AS builder
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Inference is not yet compatible with python 3.13; lets use 3.12 instead

Suggested change
FROM python:3.13-slim AS builder
FROM python:3.12-slim AS builder

cmake \
# Install system dependencies
RUN apt-get update && apt-get install -y --no-install-recommends \
libxext6 libopencv-dev git libgdal-dev cmake make ninja-build gcc g++ curl \
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd vote for restoring previous way of listing dependencies

# Using separate commands to better utilize layer caching
RUN uv pip install --upgrade pip && \
uv pip install . && \
uv pip install .[clip,container,cpu,doctr,gaze,groundingdino,http,sam,transformers,waf,yolo_world]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

since we are making quite substantial change here, I'd also vote for creating venv for the project and installing everything there; this will also result in all dependencies installed in isolated directory which should make it easier if we wanted to copy between stages


RUN if [ "${TARGETPLATFORM}" = "linux/amd64" ]; then pip3 install -r requirements/requirements.vino.txt; rm -rf ~/.cache/pip; fi
# Final stage
FROM python:3.13-slim
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
FROM python:3.13-slim
FROM python:3.12-slim


# Install system dependencies
RUN apt-get update && apt-get install -y --no-install-recommends \
libxext6 libopencv-dev git libgdal-dev cmake make ninja-build gcc g++ curl \
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd vote for restoring previous way of listing dependencies

@@ -1,3 +0,0 @@
[pytest]
markers =
slow: marks tests as slow (deselect with '-m "not slow"')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think this file should be deleted

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants