PDF-Insight-PRO / Dockerfile
Jatin Mehra
Remove Docker image deployment workflow and update Dockerfile for improved setup and environment variable handling
bb151bf
FROM python:3.12-slim
WORKDIR /app
# Install system dependencies for langchain
RUN apt-get update && apt-get install -y --no-install-recommends \
gcc \
python3-dev \
&& rm -rf /var/lib/apt/lists/*
# Create a non-root user and set up uploads directory
RUN useradd -m -s /bin/bash appuser && \
mkdir -p /app/uploads && \
chown appuser:appuser /app/uploads
# Copy application files and set permissions
COPY . .
RUN chown -R appuser:appuser /app && \
chmod -R u+rwx /app && \
chmod -R u+rwx /usr/local/lib/python3.12 /usr/local/bin
# Install dependencies and verify uvicorn
RUN python -m pip install --no-cache-dir -r requirements.txt && \
python -m pip install --no-cache-dir uvicorn && \
uvicorn --version
# Accept the secret token as a build argument
ARG GROQ_API_KEY
ARG TAVILY_API_KEY
# Docs: https://huggingface.co/docs/hub/en/spaces-sdks-docker#secrets-and-variables-management
# Expose the secret GROQ_API_KEY and OLLAMA_API_TOKEN at build time and set them as environment variables
RUN --mount=type=secret,id=GROQ_API_KEY,mode=0444,required=true \
export GROQ_API_KEY=$(cat /run/secrets/GROQ_API_KEY) && \
echo "GROQ_API_KEY is set."
RUN --mount=type=secret,id=TAVILY_API_KEY,mode=0444,required=true \
export TAVILY_API_KEY=$(cat /run/secrets/TAVILY_API_KEY) && \
echo "TAVILY_API_KEY is set."
# Set environment variables
ENV PYTHONPATH=/app \
PATH=/usr/local/bin:$PATH
# Switch to non-root user
USER appuser
# Expose Streamlit port
EXPOSE 7860
# Run the fastapi server
CMD ["uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860"]