FROM python:3.10-slim | |
# ββ Base OS packages βββββββββββββββββββββββββββββββββββββββββββββββ | |
RUN apt-get update && apt-get install -y --no-install-recommends \ | |
gcc python3-dev openssl curl ca-certificates gnupg build-essential \ | |
&& rm -rf /var/lib/apt/lists/* | |
# ββ MariaDB client libs ββββββββββββββββββββββββββββββββββββββββββββ | |
RUN curl -LsSO https://r.mariadb.com/downloads/mariadb_repo_setup && \ | |
chmod +x mariadb_repo_setup && ./mariadb_repo_setup --mariadb-server-version="mariadb-11.7" && \ | |
apt-get update && apt-get install -y --no-install-recommends \ | |
libmariadb3 libmariadb-dev && \ | |
apt-get clean && rm -rf /var/lib/apt/lists/* | |
# ββ Python tooling ββββββββββββββββββββββββββββββββββββββββββββββββ | |
RUN pip install --no-cache-dir uv==0.1.37 | |
RUN useradd -m -u 1000 user | |
WORKDIR /app | |
# Copy project files | |
COPY . /app | |
# Ensure our src/ is on the Python path so our local code is used | |
ENV PYTHONPATH=/app/src | |
# Install project (editable) + FastAPI stack in one layer | |
RUN uv pip install -e . --system && \ | |
uv pip install fastapi uvicorn[standard] --system | |
# Fix permissions so the unprivileged user can write to /app and .egg-info | |
RUN chown -R user:user /app | |
# ββ Unprivileged user βββββββββββββββββββββββββββββββββββββββββββββ | |
USER user | |
ENV HOME=/home/user \ | |
PATH=/home/user/.local/bin:$PATH \ | |
UV_NO_CACHE=1 \ | |
UV_CACHE_DIR=/dev/null \ | |
PORT=7860 | |
EXPOSE 7860 | |
# Run the server using uvicorn with app.py as the entrypoint | |
CMD ["uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860"] | |