File size: 1,968 Bytes
526927a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
55
56
57
58
59
60
61
62
63
64
65
# 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')"

# ํ•„์š”ํ•œ ๋””๋ ‰ํ† ๋ฆฌ ์ƒ์„ฑ
RUN mkdir -p /app/data /app/logs /app/models /app/uploads /app/vector_stores /app/temp /app/cache/transformers /app/cache/huggingface

# Hugging Face ์บ์‹œ ๋””๋ ‰ํ† ๋ฆฌ ํ™˜๊ฒฝ ๋ณ€์ˆ˜ ์„ค์ •
ENV TRANSFORMERS_CACHE=/app/cache/transformers
ENV HF_HOME=/app/cache/huggingface
ENV HF_HUB_CACHE=/app/cache/huggingface

# ๋ชจ๋ธ ๋‹ค์šด๋กœ๋“œ ์Šคํฌ๋ฆฝํŠธ ๋ณต์‚ฌ ๋ฐ ์‹คํ–‰
COPY download_model.py /app/download_model.py
RUN python /app/download_model.py

# ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ์ฝ”๋“œ ๋ณต์‚ฌ
COPY . .

# ๊ถŒํ•œ ์„ค์ •
RUN chmod +x /app/*.py

# 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"]