Spaces:
Running
Running
| # PV Defect Classifier — HuggingFace Spaces | |
| FROM python:3.11-slim | |
| # Run as non-root user (UID 1000) per container security best practices | |
| RUN useradd -m -u 1000 user | |
| WORKDIR /app | |
| # Install dependencies (cache layer) | |
| COPY requirements.txt . | |
| RUN pip install --no-cache-dir -r requirements.txt | |
| RUN pip install --no-cache-dir gunicorn | |
| # Copy application code (--chown avoids permission issues) | |
| COPY --chown=user app.py . | |
| COPY --chown=user templates/ templates/ | |
| COPY --chown=user models/ models/ | |
| COPY --chown=user test_images/ test_images/ | |
| # Switch to non-root user | |
| USER user | |
| ENV HOME=/home/user \ | |
| PATH=/home/user/.local/bin:$PATH | |
| # Bind to container-configured application port 7860 | |
| # 1 worker = 1 model copy in memory; timeout 120s for cold start | |
| CMD ["gunicorn", "--bind", "0.0.0.0:7860", "--workers", "1", "--timeout", "120", "app:app"] | |