Spaces:
Running
Running
# Use Python 3.11 slim-bullseye for smaller base image | |
FROM python:3.11-slim-bullseye AS builder | |
# Set environment variables | |
ENV PYTHONDONTWRITEBYTECODE=1 \ | |
PYTHONUNBUFFERED=1 \ | |
PIP_NO_CACHE_DIR=1 \ | |
PIP_DISABLE_PIP_VERSION_CHECK=1 | |
# Set the working directory | |
WORKDIR /build | |
# Install only essential build dependencies | |
RUN apt-get update && apt-get install -y --no-install-recommends \ | |
build-essential \ | |
gcc \ | |
g++ \ | |
gfortran \ | |
&& rm -rf /var/lib/apt/lists/* | |
# Install swarms packages | |
RUN pip install --no-cache-dir swarm-models swarms | |
# Production stage | |
FROM python:3.11-slim-bullseye | |
# Set secure environment variables | |
ENV PYTHONDONTWRITEBYTECODE=1 \ | |
PYTHONUNBUFFERED=1 \ | |
WORKSPACE_DIR="agent_workspace" \ | |
PATH="/app:${PATH}" \ | |
PYTHONPATH="/app:${PYTHONPATH}" \ | |
USER=swarms | |
# Create non-root user | |
RUN useradd -m -s /bin/bash -U $USER && \ | |
mkdir -p /app && \ | |
chown -R $USER:$USER /app | |
# Set working directory | |
WORKDIR /app | |
# Copy only necessary files from builder | |
COPY --from=builder /usr/local/lib/python3.11/site-packages /usr/local/lib/python3.11/site-packages | |
COPY --from=builder /usr/local/bin /usr/local/bin | |
# Copy application with correct permissions | |
COPY --chown=$USER:$USER . . | |
# Switch to non-root user | |
USER $USER | |
# Health check | |
HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \ | |
CMD python -c "import swarms; print('Health check passed')" || exit 1 |