nemaquant / Dockerfile
GitHub Actions
deploy: sync from GitHub 618f20bc48b85000312050d45345eefcae49b3c6
42cae29
# CPU image - use Dockerfile.gpu for GPU support
FROM python:3.12.13-slim-trixie
# Cache bust: 2026-03-19
# run updates before switching over to non-root user
RUN apt-get update && apt-get install -y --no-install-recommends \
libglib2.0-0 \
&& rm -rf /var/lib/apt/lists/*
# add new user with ID 1000 to avoid permission issues on HF spaces
RUN useradd -m -u 1000 user
USER user
# Set home to user's home dir and add local bin to PATH
ENV HOME=/home/user \
PATH=/home/user/.local/bin:$PATH
# Set the working directory in the container
WORKDIR $HOME/app
# Try and run pip command after setting the user with `USER user` to avoid permission issues with Python
# NOTE - this is from the HF Spaces docs, not sure if necessary
COPY --chown=user ./requirements.txt .
RUN pip install --no-cache-dir torch==2.7.1 torchvision --index-url https://download.pytorch.org/whl/cpu
RUN pip install --no-cache-dir --only-binary :all: -r requirements.txt
# Force headless opencv after ultralytics (which pulls in full opencv-python as a dependency)
RUN pip install --no-cache-dir --force-reinstall opencv-python-headless==4.13.0.92
# Copy the current directory contents into the container at $HOME/app setting the owner to the user
COPY --chown=user . $HOME/app
# Install any needed packages specified in requirements.txt
# --no-cache-dir: Disables the cache to reduce image size.
# -r requirements.txt: Specifies the file containing the list of packages to install.
# RUN pip install --no-cache-dir -r requirements.txt
# Create the necessary dirs
# we should not need to chown, since we are using USER user above
RUN mkdir -p uploads results annotated .yolo_config
# set the env var for YOLO user config directory
ENV YOLO_CONFIG_DIR=$HOME/app/.yolo_config
# Copy the rest of the application code into the container at /app
# This includes app.py, nemaquant.py, templates/, static/, etc.
# COPY . .
# Make port 7860 available to the world outside this container
# This is the port Flask will run on (as configured in app.py)
# Hugging Face Spaces typically uses this port
EXPOSE 7860
# Define environment variables (optional, can be useful)
# ENV NAME=World
# Run app.py when the container launches
# Use gunicorn for production deployment if preferred over Flask's development server
# CMD ["gunicorn", "--bind", "0.0.0.0:7860", "app:app"]
# For simplicity during development and typical HF Spaces use:
CMD ["python", "app.py"]