lily_fast_api / Dockerfile.huggingface
gbrabbit's picture
Fresh start for HF Spaces deployment
526927a
# Hugging Face Spaces์šฉ Lily LLM API Server Dockerfile
FROM python:3.11-slim
# Hugging Face Spaces ํ™˜๊ฒฝ ๋ณ€์ˆ˜
ENV GRADIO_SERVER_NAME="0.0.0.0"
ENV GRADIO_SERVER_PORT=7860
ENV PYTHONPATH=/app
ENV PYTHONUNBUFFERED=1
ENV TOKENIZERS_PARALLELISM=false
# ์ž‘์—… ๋””๋ ‰ํ† ๋ฆฌ ์„ค์ •
WORKDIR /app
# ์‹œ์Šคํ…œ ์˜์กด์„ฑ ์„ค์น˜
RUN apt-get update && apt-get install -y \
build-essential \
curl \
git \
wget \
ffmpeg \
libsm6 \
libxext6 \
libfontconfig1 \
libxrender1 \
libgl1-mesa-glx \
&& rm -rf /var/lib/apt/lists/*
# Python ์˜์กด์„ฑ ์„ค์น˜ (์บ์‹ฑ ์ตœ์ ํ™”)
COPY requirements_full.txt requirements.txt
RUN pip install --no-cache-dir --upgrade pip
RUN pip install --no-cache-dir -r requirements.txt
# NLTK ๋ฐ์ดํ„ฐ ๋‹ค์šด๋กœ๋“œ
RUN python -c "import nltk; nltk.download('punkt'); nltk.download('punkt_tab'); nltk.download('averaged_perceptron_tagger'); nltk.download('maxent_ne_chunker'); nltk.download('words'); nltk.download('stopwords')"
# ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ์ฝ”๋“œ ๋ณต์‚ฌ
COPY . .
# ํ•„์š”ํ•œ ๋””๋ ‰ํ† ๋ฆฌ ์ƒ์„ฑ
RUN mkdir -p /app/data /app/logs /app/models /app/uploads /app/vector_stores /app/temp /app/cache/transformers /app/cache/huggingface
# ๊ถŒํ•œ ์„ค์ •
RUN chmod +x /app/*.py
# Hugging Face ์บ์‹œ ๋””๋ ‰ํ† ๋ฆฌ ํ™˜๊ฒฝ ๋ณ€์ˆ˜ ์„ค์ •
ENV TRANSFORMERS_CACHE=/app/cache/transformers
ENV HF_HOME=/app/cache/huggingface
ENV HF_HUB_CACHE=/app/cache/huggingface
# ํ™˜๊ฒฝ ๊ฐ์ง€ ์„ค์ •
ENV IS_LOCAL=false
ENV ENVIRONMENT=production
ENV DOCKER_ENV=server
# Hugging Face Spaces์šฉ ์•ฑ ์‹œ์ž‘์  ์ƒ์„ฑ
COPY app_huggingface.py /app/app_huggingface.py
# ํฌํŠธ ๋…ธ์ถœ (Hugging Face Spaces๋Š” 7860 ํฌํŠธ ์‚ฌ์šฉ)
EXPOSE 7860
# ํ—ฌ์Šค์ฒดํฌ
HEALTHCHECK --interval=30s --timeout=30s --start-period=60s --retries=3 \
CMD curl -f http://localhost:7860/health || exit 1
# ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ์‹คํ–‰
CMD ["python", "app_huggingface.py"]