| |
| |
|
|
| FROM python:3.11-slim as builder |
|
|
| |
| ENV PYTHONDONTWRITEBYTECODE=1 \ |
| PYTHONUNBUFFERED=1 \ |
| PIP_NO_CACHE_DIR=1 \ |
| PIP_DISABLE_PIP_VERSION_CHECK=1 |
|
|
| |
| RUN apt-get update && apt-get install -y \ |
| build-essential \ |
| curl \ |
| git \ |
| && rm -rf /var/lib/apt/lists/* |
|
|
| |
| RUN python -m venv /opt/venv |
| ENV PATH="/opt/venv/bin:$PATH" |
|
|
| |
| COPY requirements.txt . |
| RUN pip install --upgrade pip && \ |
| pip install -r requirements.txt |
|
|
| |
| FROM python:3.11-slim |
|
|
| |
| ENV PYTHONDONTWRITEBYTECODE=1 \ |
| PYTHONUNBUFFERED=1 \ |
| PATH="/opt/venv/bin:$PATH" \ |
| PYTHONPATH="/app" |
|
|
| |
| RUN apt-get update && apt-get install -y \ |
| curl \ |
| && rm -rf /var/lib/apt/lists/* |
|
|
| |
| COPY --from=builder /opt/venv /opt/venv |
|
|
| |
| RUN groupadd -r appuser && useradd -r -g appuser appuser |
| WORKDIR /app |
|
|
| |
| COPY . . |
|
|
| |
| RUN mkdir -p logs && \ |
| chown -R appuser:appuser /app |
|
|
| |
| USER appuser |
|
|
| |
| EXPOSE 7860 |
|
|
| |
| HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \ |
| CMD curl -f http://localhost:7860/health || exit 1 |
|
|
| |
| CMD ["python", "-m", "uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "7860"] |
|
|