-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
101 lines (82 loc) · 4.53 KB
/
Dockerfile
File metadata and controls
101 lines (82 loc) · 4.53 KB
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# Gangajikimi FastAPI 서버용 멀티 스테이지, CPU 전용, 최소 런타임 이미지
# 1단계: 휠 파일들을 미리 다운로드해서 최종 이미지에 빌드 도구 없이 최소 레이어로 구성
ARG PYTHON_VERSION=3.13
FROM python:${PYTHON_VERSION}-slim AS wheels
# Python 환경 변수 설정
ENV PIP_DISABLE_PIP_VERSION_CHECK=1 \
PIP_NO_CACHE_DIR=1 \
PYTHONDONTWRITEBYTECODE=1 \
PYTHONUNBUFFERED=1
WORKDIR /w
# 캐시 히트를 최대화하기 위해 requirements 파일만 복사
COPY requirements/requirements-base.txt requirements/requirements-base.txt
COPY requirements/requirements-cpu.txt requirements/requirements-cpu.txt
# PyTorch 등 모든 의존성의 휠 파일을 미리 다운로드 (CPU 버전)
RUN python -m pip install --upgrade pip && \
pip wheel --wheel-dir /wheels \
-r requirements/requirements-base.txt \
-r requirements/requirements-cpu.txt
# 2단계: 실제 런타임 이미지 (최종 배포용)
FROM python:3.13-slim AS runtime
# Python 빌드 환경 변수 설정 (빌드 시점에만 필요)
ENV PIP_DISABLE_PIP_VERSION_CHECK=1 \
PIP_NO_CACHE_DIR=1 \
PYTHONDONTWRITEBYTECODE=1 \
PYTHONUNBUFFERED=1
# 런타임 환경 변수는 app/domain/config.py에서 관리
WORKDIR /app
# opencv-python-headless, numpy, torch에 필요한 최소 시스템 라이브러리만 설치
# 불필요한 개발 도구 및 GUI 라이브러리 제거로 이미지 크기 최소화
RUN apt-get update && \
apt-get install -y --no-install-recommends \
libglib2.0-0 \
libgl1 \
libsm6 \
libxext6 \
libxrender1 \
libgomp1 \
libgfortran5 \
&& rm -rf /var/lib/apt/lists/* \
&& apt-get clean \
&& apt-get autoremove -y
# 1단계에서 다운로드한 휠 파일들을 복사해서 설치 후 삭제 (단일 레이어로 최적화)
COPY --from=wheels /wheels /tmp/wheels
RUN python -m pip install --no-index --find-links=/tmp/wheels /tmp/wheels/* && \
rm -rf /tmp/wheels && \
# ⭐ 불필요한 파일 제거로 이미지 크기 대폭 축소 (50-150MB 절감)
find /usr/local/lib/python*/site-packages -type d -name "tests" -exec rm -rf {} + 2>/dev/null || true && \
find /usr/local/lib/python*/site-packages -type d -name "test" -exec rm -rf {} + 2>/dev/null || true && \
find /usr/local/lib/python*/site-packages -type d -name "examples" -exec rm -rf {} + 2>/dev/null || true && \
find /usr/local/lib/python*/site-packages -type d -name "docs" -exec rm -rf {} + 2>/dev/null || true && \
find /usr/local/lib/python*/site-packages -name "*.pyc" -delete && \
find /usr/local/lib/python*/site-packages -name "*.pyo" -delete && \
find /usr/local/lib/python*/site-packages -name "__pycache__" -type d -exec rm -rf {} + 2>/dev/null || true && \
# PyTorch 불필요한 파일 제거
find /usr/local/lib/python*/site-packages/torch -name "*.a" -delete 2>/dev/null || true && \
# Ultralytics 불필요한 assets, datasets 제거
rm -rf /usr/local/lib/python*/site-packages/ultralytics/assets/*.jpg 2>/dev/null || true && \
rm -rf /usr/local/lib/python*/site-packages/ultralytics/cfg/datasets/*.yaml 2>/dev/null || true && \
# Locale 데이터 최소화 (영어, 한국어만 유지)
find /usr/share/locale -mindepth 1 -maxdepth 1 ! -name 'en*' ! -name 'ko*' ! -name 'locale.alias' -exec rm -rf {} + 2>/dev/null || true && \
# Man pages 제거
rm -rf /usr/share/man/* 2>/dev/null || true && \
# Doc 제거
rm -rf /usr/share/doc/* 2>/dev/null || true
# 필요한 프로젝트 파일들만 복사
COPY app/ /app/app/
COPY yolov8s.pt /app/yolov8s.pt
# 보안을 위해 비루트 사용자 생성 (CLIP 다운로드 전에 생성)
RUN useradd -m -u 10001 appuser && \
mkdir -p /app/.cache/huggingface && \
chown -R appuser:appuser /app
# CLIP 모델 사전 다운로드 (BuildKit 캐시 마운트로 속도 향상)
RUN --mount=type=cache,target=/app/.cache/huggingface,uid=10001,gid=10001 \
python -c "import open_clip; open_clip.create_model_and_transforms('ViT-B-32', pretrained='laion2b_s34b_b79k')" && \
echo "CLIP model downloaded and cached"
USER appuser
# 포트 8000 노출
EXPOSE 8000
# 헬스체크: 3분마다 /openapi.json에 접근해서 서버 상태 확인
HEALTHCHECK --interval=180s --timeout=5s --retries=3 CMD python -c "import urllib.request; urllib.request.urlopen('http://127.0.0.1:8000/openapi.json', timeout=3)"
# 프로덕션용 기본 명령어 (reload 비활성화). 필요시 CMD/args로 변경 가능
CMD ["python", "-m", "uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000"]