# 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/engine/reference/builder/ | |
ARG PYTHON_VERSION=3.9 | |
FROM python:${PYTHON_VERSION}-slim as base | |
RUN apt-get update && apt-get install -y \ | |
build-essential \ | |
curl \ | |
software-properties-common \ | |
git \ | |
&& rm -rf /var/lib/apt/lists/* | |
# Copy the requirements file into the container. | |
COPY requirements.txt . | |
# Install the dependencies from the requirements file. | |
RUN pip3 install --no-cache-dir -r requirements.txt | |
# 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 | |
WORKDIR /app | |
# Copy the source code into the container. | |
COPY . . | |
# Create a non-privileged user that the app will run under. | |
# See https://docs.docker.com/develop/develop-images/dockerfile_best-practices/#user | |
# Switch to the non-privileged user to run the application. | |
USER 1001 | |
# Expose the port that the application listens on. | |
EXPOSE 7860 | |
HEALTHCHECK CMD curl --fail http://localhost:7860/_stcore/health | |
# set entrypoint for interactive shells | |
ENTRYPOINT ["streamlit", "run", "app.py", "--server.port=7860", "--server.address=0.0.0.0"] | |