improve dockerfile
All checks were successful
All checks were successful
This commit is contained in:
40
Dockerfile
40
Dockerfile
@@ -2,6 +2,9 @@
|
|||||||
# Stage 1: Builder
|
# Stage 1: Builder
|
||||||
FROM python:3.11-slim as builder
|
FROM python:3.11-slim as builder
|
||||||
|
|
||||||
|
# Create non-root user early in builder stage
|
||||||
|
RUN groupadd -r appuser && useradd -r -g appuser appuser
|
||||||
|
|
||||||
# Install system dependencies for building Python packages
|
# Install system dependencies for building Python packages
|
||||||
RUN apt-get update && apt-get install -y \
|
RUN apt-get update && apt-get install -y \
|
||||||
build-essential \
|
build-essential \
|
||||||
@@ -25,6 +28,15 @@ COPY wsgi.py .
|
|||||||
COPY run_prod.py .
|
COPY run_prod.py .
|
||||||
COPY assets/ assets/
|
COPY assets/ assets/
|
||||||
|
|
||||||
|
# Change ownership of source files before building (lighter I/O)
|
||||||
|
RUN chown -R appuser:appuser /app
|
||||||
|
|
||||||
|
# Create and set permissions for appuser home directory (needed for uv cache)
|
||||||
|
RUN mkdir -p /home/appuser && chown -R appuser:appuser /home/appuser
|
||||||
|
|
||||||
|
# Switch to non-root user before building
|
||||||
|
USER appuser
|
||||||
|
|
||||||
# Create virtual environment and install dependencies (including production extras)
|
# Create virtual environment and install dependencies (including production extras)
|
||||||
RUN uv venv .venv
|
RUN uv venv .venv
|
||||||
RUN uv sync --frozen --extra prod
|
RUN uv sync --frozen --extra prod
|
||||||
@@ -32,23 +44,28 @@ RUN uv sync --frozen --extra prod
|
|||||||
# Stage 2: Runtime
|
# Stage 2: Runtime
|
||||||
FROM python:3.11-slim as runtime
|
FROM python:3.11-slim as runtime
|
||||||
|
|
||||||
|
# Create non-root user in runtime stage
|
||||||
|
RUN groupadd -r appuser && useradd -r -g appuser appuser
|
||||||
|
|
||||||
# Install runtime dependencies for compiled packages
|
# Install runtime dependencies for compiled packages
|
||||||
RUN apt-get update && apt-get install -y \
|
RUN apt-get update && apt-get install -y \
|
||||||
libgomp1 \
|
libgomp1 \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Set working directory
|
# Set working directory and change ownership (small directory)
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
RUN chown appuser:appuser /app
|
||||||
|
|
||||||
# Copy virtual environment from builder stage
|
# Copy files from builder with correct ownership
|
||||||
COPY --from=builder /app/.venv /app/.venv
|
COPY --from=builder --chown=appuser:appuser /app/.venv /app/.venv
|
||||||
|
COPY --from=builder --chown=appuser:appuser /app/src /app/src
|
||||||
|
COPY --from=builder --chown=appuser:appuser /app/main.py /app/main.py
|
||||||
|
COPY --from=builder --chown=appuser:appuser /app/assets /app/assets
|
||||||
|
COPY --from=builder --chown=appuser:appuser /app/wsgi.py /app/wsgi.py
|
||||||
|
COPY --from=builder --chown=appuser:appuser /app/run_prod.py /app/run_prod.py
|
||||||
|
|
||||||
# Copy application files from builder stage
|
# Switch to non-root user
|
||||||
COPY --from=builder /app/src /app/src
|
USER appuser
|
||||||
COPY --from=builder /app/main.py /app/main.py
|
|
||||||
COPY --from=builder /app/assets /app/assets
|
|
||||||
COPY --from=builder /app/wsgi.py /app/wsgi.py
|
|
||||||
COPY --from=builder /app/run_prod.py /app/run_prod.py
|
|
||||||
|
|
||||||
# Make sure the virtual environment is in PATH
|
# Make sure the virtual environment is in PATH
|
||||||
ENV PATH="/app/.venv/bin:$PATH"
|
ENV PATH="/app/.venv/bin:$PATH"
|
||||||
@@ -65,11 +82,6 @@ ENV EMBEDDINGBUDDY_ENV=production
|
|||||||
# Expose port
|
# Expose port
|
||||||
EXPOSE 8050
|
EXPOSE 8050
|
||||||
|
|
||||||
# Create non-root user
|
|
||||||
RUN groupadd -r appuser && useradd -r -g appuser appuser
|
|
||||||
RUN chown -R appuser:appuser /app
|
|
||||||
USER appuser
|
|
||||||
|
|
||||||
# Health check
|
# Health check
|
||||||
HEALTHCHECK --interval=30s --timeout=10s --start-period=30s --retries=3 \
|
HEALTHCHECK --interval=30s --timeout=10s --start-period=30s --retries=3 \
|
||||||
CMD python -c "import requests; requests.get('http://localhost:8050/', timeout=5)" || exit 1
|
CMD python -c "import requests; requests.get('http://localhost:8050/', timeout=5)" || exit 1
|
||||||
|
Reference in New Issue
Block a user