The tod-mib-parser at /app/ was overwritten by COPY backend/ . Move to /usr/local/bin/ and update config path. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
67 lines
1.9 KiB
Docker
67 lines
1.9 KiB
Docker
# Multi-stage build for TOD API
|
|
# Stage 0: build MIB parser binary from Go source
|
|
FROM golang:1.25-alpine AS mib-builder
|
|
WORKDIR /build
|
|
COPY poller/go.mod poller/go.sum ./
|
|
RUN go mod download
|
|
COPY poller/ .
|
|
RUN CGO_ENABLED=0 GOOS=linux GOMAXPROCS=1 go build -o /tod-mib-parser ./cmd/mib-parser
|
|
|
|
# Stage 1: build — install Python deps
|
|
FROM python:3.12-slim AS builder
|
|
|
|
# Install system dependencies needed for asyncpg (libpq-dev) and cryptography
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
libpq-dev \
|
|
gcc \
|
|
build-essential \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
WORKDIR /build
|
|
|
|
# Copy and install Python dependencies first (layer cache optimization)
|
|
COPY backend/pyproject.toml ./
|
|
# Create a minimal README.md so pip install doesn't fail (pyproject.toml references it)
|
|
RUN echo "# TOD API" > README.md
|
|
RUN pip install --no-cache-dir --upgrade pip && \
|
|
pip install --no-cache-dir --prefix=/install .
|
|
|
|
# Stage 2: runtime — lean production image
|
|
FROM python:3.12-slim AS runtime
|
|
|
|
# Runtime system deps: libpq for asyncpg, pango/cairo/gdk-pixbuf for weasyprint PDF generation
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
libpq5 \
|
|
libpango-1.0-0 \
|
|
libpangocairo-1.0-0 \
|
|
libpangoft2-1.0-0 \
|
|
libcairo2 \
|
|
libgdk-pixbuf-2.0-0 \
|
|
libglib2.0-0 \
|
|
libffi8 \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Create a non-root user for security
|
|
RUN groupadd --gid 1001 appuser && \
|
|
useradd --uid 1001 --gid appuser --no-create-home appuser
|
|
|
|
WORKDIR /app
|
|
|
|
# Copy installed packages from builder
|
|
COPY --from=builder /install /usr/local
|
|
|
|
# Copy application source
|
|
COPY backend/ .
|
|
|
|
# Copy MIB parser binary from Go builder stage (after COPY backend/ so it's not overwritten)
|
|
COPY --from=mib-builder /tod-mib-parser /usr/local/bin/tod-mib-parser
|
|
|
|
# Change ownership to non-root user
|
|
RUN chown -R appuser:appuser /app
|
|
|
|
USER appuser
|
|
|
|
EXPOSE 8000
|
|
|
|
CMD ["gunicorn", "app.main:app", "--config", "gunicorn.conf.py"]
|