AroojImtiaz's picture
Update Dockerfile
5420a0a verified
# syntax=docker/dockerfile:1
# Base image using the specified Python version
ARG PYTHON_VERSION=3.12.3
FROM python:${PYTHON_VERSION}-slim as base
# Set environment variables to prevent Python from writing .pyc files
# and to keep Python from buffering stdout and stderr
ENV PYTHONDONTWRITEBYTECODE=1 \
PYTHONUNBUFFERED=1
# Set working directory inside the container
WORKDIR /app
# Install TensorFlow, Keras, and tf-keras
# Using a single RUN command to reduce layers
RUN pip install tensorflow==2.16.1 keras tf-keras
# Create a non-privileged user to run the application
# Follow best practices from Docker's user handling
ARG UID=10001
RUN adduser --disabled-password --gecos "" --home "/nonexistent" \
--shell "/sbin/nologin" --no-create-home --uid "${UID}" appuser
# Prepare environment for Transformers and NLTK
# Creating cache directories with appropriate permissions
ENV TRANSFORMERS_CACHE=/tmp/.cache/huggingface \
NLTK_DATA=/tmp/nltk_data
RUN mkdir -p $TRANSFORMERS_CACHE $NLTK_DATA && chmod -R 777 $TRANSFORMERS_CACHE $NLTK_DATA
# Copy the Python requirements file and install dependencies
# Using a single COPY to reduce layers and ensure requirements.txt is present
COPY requirements.txt .
RUN pip install -r requirements.txt
# Copy the rest of the application source code into the container
COPY . .
# Switch to the non-privileged user for running the application
USER appuser
# Expose the port that the application will listen on
EXPOSE 7860
# Command to run the application using uvicorn
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "7860"]