| # syntax=docker/dockerfile:1 | |
| # Comments are provided throughout this file to help you get started. | |
| # If you need more help, visit the Dockerfile reference guide at | |
| # https://docs.docker.com/go/dockerfile-reference/ | |
| # Want to help us make this template better? Share your feedback here: https://forms.gle/ybq9Krt8jtBL3iCk7 | |
| ARG PYTHON_VERSION=3.12.4 | |
| FROM python:${PYTHON_VERSION}-slim AS base | |
| # Prevents Python from writing pyc files. | |
| ENV PYTHONDONTWRITEBYTECODE=1 | |
| # Keeps Python from buffering stdout and stderr to avoid situations where | |
| # the application crashes without emitting any logs due to buffering. | |
| ENV PYTHONUNBUFFERED=1 | |
| ENV SECRET_KEY=53ng5(^guxf_!l0@5ka(54l!z=wsh0mmlq%v))kr9#%t*vo*&l | |
| WORKDIR /app | |
| COPY requirements.txt . | |
| RUN pip install -r requirements.txt | |
| COPY . . | |
| EXPOSE 8000 | |
| # CMD ["python3", "manage.py", "runserver"] | |
| # CMD ["python3", "manage.py", "runserver", "0.0.0.0:8000"] | |
| # CMD ["gunicorn", "setup.wsgi"] | |
| # CMD ["gunicorn", "setup.wsgi:application", "--bind", ":8000"] | |
| CMD ["uvicorn", "setup.asgi:application", "--host", "0.0.0.0", "--port", "7860"] | |
| # # Create a non-privileged user that the app will run under. | |
| # # See https://docs.docker.com/go/dockerfile-user-best-practices/ | |
| # ARG UID=10001 | |
| # RUN adduser \ | |
| # --disabled-password \ | |
| # --gecos "" \ | |
| # --home "/nonexistent" \ | |
| # --shell "/sbin/nologin" \ | |
| # --no-create-home \ | |
| # --uid "${UID}" \ | |
| # appuser | |
| # # Download dependencies as a separate step to take advantage of Docker's caching. | |
| # # Leverage a cache mount to /root/.cache/pip to speed up subsequent builds. | |
| # # Leverage a bind mount to requirements.txt to avoid having to copy them into | |
| # # into this layer. | |
| # RUN --mount=type=cache,target=/root/.cache/pip \ | |
| # --mount=type=bind,source=requirements.txt,target=requirements.txt \ | |
| # python -m pip install -r requirements.txt | |
| # # Switch to the non-privileged user to run the application. | |
| # USER appuser | |
| # # Copy the source code into the container. | |
| # COPY . . | |
| # # Expose the port that the application listens on. | |
| # EXPOSE 8000 | |
| # # Run the application. | |
| # # CMD gunicorn '.venv.Lib.site-packages.asgiref.wsgi' --bind=0.0.0.0:8000 | |
| # CMD python manage.py runserver | |