embeddings-api / Dockerfile
Soumik Bose
ok
3b07301
# Use the official Python 3.11 slim image
FROM python:3.11-slim
# Set environment variables
ENV PYTHONDONTWRITEBYTECODE=1 \
PYTHONUNBUFFERED=1 \
PYTHONIOENCODING=UTF-8 \
HF_HOME=/app/cache
# Install system dependencies
RUN apt-get update && apt-get install -y --no-install-recommends curl \
&& rm -rf /var/lib/apt/lists/* \
&& useradd -m -u 1000 user
WORKDIR /app
# --- LAYER 1: Dependencies ---
COPY --chown=user:user requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
# --- LAYER 2: Download Models (Cached) ---
# We download models for 384, 768, and 1024 dimensions.
# 384 dim: BAAI/bge-small-en-v1.5
# 768 dim: BAAI/bge-base-en-v1.5
# 1024 dim: BAAI/bge-large-en-v1.5
RUN python3 -c "from huggingface_hub import snapshot_download; \
snapshot_download(repo_id='BAAI/bge-small-en-v1.5', local_dir='./models/bge-384'); \
snapshot_download(repo_id='BAAI/bge-base-en-v1.5', local_dir='./models/bge-768'); \
snapshot_download(repo_id='BAAI/bge-large-en-v1.5', local_dir='./models/bge-1024')"
# --- LAYER 3: Application Code ---
COPY --chown=user:user . .
# Ensure permissions
RUN mkdir -p $HF_HOME && chown -R user:user /app/cache && chown -R user:user /app/models
# Switch user
USER user
# Expose port
EXPOSE 7860
# Start script
CMD bash -c "while true; do curl -s https://xce009-embeddings-api.hf.space/ping >/dev/null && sleep 300; done & uvicorn main:app --host 0.0.0.0 --port 7860 --workers 4 --loop asyncio"