| # TorchForge Production Dockerfile | |
| # Author: Anil Prasad | |
| # Multi-stage build for optimized production deployment | |
| # Stage 1: Builder | |
| FROM python:3.10-slim as builder | |
| WORKDIR /build | |
| # Install build dependencies | |
| RUN apt-get update && apt-get install -y \ | |
| build-essential \ | |
| git \ | |
| && rm -rf /var/lib/apt/lists/* | |
| # Copy requirements | |
| COPY requirements.txt . | |
| # Install Python dependencies | |
| RUN pip install --no-cache-dir --user -r requirements.txt | |
| # Stage 2: Production | |
| FROM python:3.10-slim | |
| LABEL maintainer="Anil Prasad <anilprasad@example.com>" | |
| LABEL description="TorchForge - Enterprise-Grade PyTorch Framework" | |
| LABEL version="1.0.0" | |
| WORKDIR /app | |
| # Install runtime dependencies | |
| RUN apt-get update && apt-get install -y \ | |
| libgomp1 \ | |
| && rm -rf /var/lib/apt/lists/* | |
| # Copy Python dependencies from builder | |
| COPY --from=builder /root/.local /root/.local | |
| # Copy application code | |
| COPY torchforge/ /app/torchforge/ | |
| COPY setup.py /app/ | |
| COPY README.md /app/ | |
| # Install TorchForge | |
| RUN pip install --no-cache-dir -e . | |
| # Create non-root user | |
| RUN useradd -m -u 1000 torchforge && \ | |
| chown -R torchforge:torchforge /app | |
| USER torchforge | |
| # Expose port for API | |
| EXPOSE 8000 | |
| # Health check | |
| HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ | |
| CMD python -c "import torchforge; print('healthy')" || exit 1 | |
| # Default command | |
| CMD ["python", "-m", "torchforge.api.server"] | |