Hardened Dockerfile
All checks were successful
Build & Publish to GHCR / build (push) Successful in 1m0s

Switched to multi stage process to harden the Dockerfile
This commit is contained in:
Florian 2025-11-04 09:54:56 +01:00
parent db118cce55
commit 8aee29ab1f

View File

@ -1,13 +1,18 @@
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"]