Spaces:
Running
Running
File size: 1,614 Bytes
bb151bf e755ec9 bb151bf e755ec9 bb151bf e755ec9 bb151bf 4e55398 bb151bf 4e55398 bb151bf e755ec9 bb151bf e755ec9 bb151bf e755ec9 bb151bf |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 |
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"] |