Hardened Dockerfile

Switched to multi stage process to harden the Dockerfile
This commit is contained in:
florian 2025-11-03 20:54:53 +01:00
parent 52390e3c45
commit 322cd3baa2

View File

@ -1,15 +1,17 @@
FROM python:3.12-slim
RUN apt-get update && apt-get install -y git
# Builder stage
FROM python:3.12-slim AS builder
RUN apt-get update \
&& apt-get install -y --no-install-recommends git build-essential \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /install
COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
RUN pip install --prefix=/install --no-cache-dir -r requirements.txt
WORKDIR /app
COPY src/ /app/
ENTRYPOINT ["python","main.py"]
# Runtime image
FROM nvcr.io/nvidia/distroless/python:3.12-v3.5.1
COPY --from=builder /install /usr/local
COPY --from=builder /app /app
WORKDIR /app
ENTRYPOINT ["python", "main.py"]