simran0608's picture
Update Dockerfile
01aa22b verified
raw
history blame
1.24 kB
FROM python:3.9-slim
WORKDIR /app
# Install system dependencies
RUN apt-get update && apt-get install -y \
build-essential \
curl \
software-properties-common \
git \
libgl1 \
&& rm -rf /var/lib/apt/lists/*
# Copy requirements and source code BEFORE creating the non-root user
# to take advantage of Docker layer caching.
COPY requirements.txt ./
COPY src/ ./src/
# Install Python dependencies as root
RUN pip3 install --no-cache-dir -r requirements.txt
# --- Create a non-root user and grant permissions ---
# Create a group and user
RUN groupadd --system appuser && useradd --system --gid appuser appuser
# Change ownership of the app directory to the new user
# This allows the app to write config/cache files
RUN chown -R appuser:appuser /app
# Switch to the non-root user
USER appuser
# --- End of user creation section ---
# You no longer need these lines as chown handles permissions for the entire /app directory
# RUN mkdir -p /app/.streamlit /app/.config
# ENV HOME=/app
# ENV XDG_CONFIG_HOME=/app/.config
EXPOSE 8501
HEALTHCHECK CMD curl --fail http://localhost:8501/_stcore/health || exit 1
ENTRYPOINT ["streamlit", "run", "src/streamlit_app.py", "--server.port=8501", "--server.address=0.0.0.0"]