성현 김 commited on
Commit
89985ec
·
1 Parent(s): 503f0d1

Refactor Dockerfile: Consolidate cache dir creation and organize ENV variables

Browse files
Files changed (1) hide show
  1. Dockerfile +18 -24
Dockerfile CHANGED
@@ -1,6 +1,5 @@
1
  # 1. 기본 이미지 설정 (Python 버전 명시)
2
  # README.md에서 python_version: 3.9.13을 지정했으므로, 일관성을 위해 여기도 맞춥니다.
3
- # <--- 변경 제안 1 (이렇게 주석 내용을 윗줄로 옮기거나, 이 주석 줄 자체를 삭제해도 됩니다)
4
  FROM python:3.9.13-slim
5
 
6
  # 2. 작업 디렉토리 설정
@@ -9,54 +8,49 @@ WORKDIR /app
9
  # 3. 시스템 의존성 설치
10
  # Konlpy (Okt) 사용을 위해 OpenJDK 설치
11
  RUN apt-get update && apt-get install -y --no-install-recommends openjdk-17-jre-headless && apt-get clean && rm -rf /var/lib/apt/lists/*
12
- # openjdk-17-jre-headless 설치는 이전 로그에서 성공했으므로 유지합니다. Konlpy는 보통 최신 LTS Java와 잘 호환됩니다.
13
 
14
  # 4. Python 의존성 설치
15
  COPY requirements.txt .
16
  RUN pip install --no-cache-dir --upgrade pip
17
 
18
- # requirements.txt 내용 확인 및 pip install 상세 로그 출력 (이전 제안)
19
  RUN echo "--- Contents of requirements.txt inside Docker build context: ---" && \
20
  cat /app/requirements.txt && \
21
  echo "--- End of requirements.txt contents ---" && \
22
  echo "--- Attempting to install packages from requirements.txt (verbose mode) ---" && \
23
- pip install --no-cache-dir -vvv -r requirements.txt # <--- -vvv 옵션으로 매우 상세한 로그 확인
24
-
25
- # uvicorn 설치 확인 및 PATH 확인 (이전 제안)
26
 
 
27
  RUN echo "--- Checking uvicorn and PATH after pip install ---" && \
28
  (which uvicorn || echo "uvicorn not found in PATH") && \
29
  echo "PATH is: $PATH" && \
30
  echo "--- End of check ---"
31
- # 애플리케이션 코드 복사 전에 캐시 디렉토리 생성 및 권한 설정
32
- RUN mkdir -p /app/.cache/huggingface/hub /app/.cache/huggingface/transformers /app/.cache/huggingface/sentence_transformers && \
 
 
 
33
  chmod -R 777 /app/.cache
 
 
34
 
35
  # 5. 애플리케이션 코드 및 데이터 복사
36
  COPY ./app /app/app
37
  COPY ./chroma_db_data /app/chroma_db_data
38
  # COPY ./fine_tuned_model /app/fine_tuned_model # 필요시 주석 해제
39
 
40
- # 6. 환경 변수 설정 (필요한 경우)
41
- # JAVA_HOME: konlpy가 내부적으로 잘 찾습니다. 문제가 될 경우 명시적으로 설정합니다.
42
- # Debian에서 OpenJDK 17의 일반적인 경로는 /usr/lib/jvm/java-17-openjdk-amd64 입니다.
43
- # 설치된 OpenJDK 버전에 맞게 설정합니다.
44
  ENV JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64
 
 
 
 
 
45
  # ENV PYTHONUNBUFFERED=1 # 로그 즉시 확인 등에 유용
46
  # ENV PROJECT_ROOT=/app
47
- # ... (ENV JAVA_HOME 이전 또는 이후)
48
- ENV HF_HOME=/app/cache/huggingface
49
- ENV HF_HUB_CACHE=/app/cache/huggingface/hub
50
- ENV TRANSFORMERS_CACHE=/app/cache/huggingface/transformers
51
- ENV SENTENCE_TRANSFORMERS_HOME=/app/cache/huggingface/sentence_transformers
52
- # (필요하다면 RUN mkdir -p /app/cache/huggingface 와 같이 폴더 생성 명령 추가)
53
  # 7. 실행할 포트 설정
54
  EXPOSE 7860
55
 
56
  # 8. 애플리케이션 실행 명령어
57
- # 이전에 app.py로 바꾸셨다고 가정하고 app.app:app 으로 작성합니다.
58
- # 만약 app/main.py를 사용하고 그 안에 app = FastAPI()가 있다면 app.main:app으로 수정하세요.
59
- # ... (다른 ENV 설정들 아래 또는 CMD 바로 위)
60
- ENV PYTHONPATH=/app
61
- CMD ["uvicorn", "app.app:app", "--host", "0.0.0.0", "--port", "7860"]
62
-
 
1
  # 1. 기본 이미지 설정 (Python 버전 명시)
2
  # README.md에서 python_version: 3.9.13을 지정했으므로, 일관성을 위해 여기도 맞춥니다.
 
3
  FROM python:3.9.13-slim
4
 
5
  # 2. 작업 디렉토리 설정
 
8
  # 3. 시스템 의존성 설치
9
  # Konlpy (Okt) 사용을 위해 OpenJDK 설치
10
  RUN apt-get update && apt-get install -y --no-install-recommends openjdk-17-jre-headless && apt-get clean && rm -rf /var/lib/apt/lists/*
 
11
 
12
  # 4. Python 의존성 설치
13
  COPY requirements.txt .
14
  RUN pip install --no-cache-dir --upgrade pip
15
 
16
+ # requirements.txt 내용 확인 및 pip install 상세 로그 출력
17
  RUN echo "--- Contents of requirements.txt inside Docker build context: ---" && \
18
  cat /app/requirements.txt && \
19
  echo "--- End of requirements.txt contents ---" && \
20
  echo "--- Attempting to install packages from requirements.txt (verbose mode) ---" && \
21
+ pip install --no-cache-dir -vvv -r requirements.txt
 
 
22
 
23
+ # uvicorn 설치 확인 및 PATH 확인
24
  RUN echo "--- Checking uvicorn and PATH after pip install ---" && \
25
  (which uvicorn || echo "uvicorn not found in PATH") && \
26
  echo "PATH is: $PATH" && \
27
  echo "--- End of check ---"
28
+
29
+ # 캐시 디렉토리 생성 모든 사용자에게 쓰기 권한 부여 (애플리케이션 코드 복사 전)
30
+ RUN mkdir -p /app/.cache/huggingface/hub \
31
+ /app/.cache/huggingface/transformers \
32
+ /app/.cache/huggingface/sentence_transformers && \
33
  chmod -R 777 /app/.cache
34
+ # 참고: /app/cache/huggingface_embeddings 경로는 HuggingFaceEmbeddings에서 cache_folder 인자를 사용하지 않기로 했으므로 여기서는 제외했습니다.
35
+ # 만약 특정 라이브러리가 /app/cache를 직접 사용한다면 chmod -R 777 /app/.cache 만으로도 충분할 수 있습니다.
36
 
37
  # 5. 애플리케이션 코드 및 데이터 복사
38
  COPY ./app /app/app
39
  COPY ./chroma_db_data /app/chroma_db_data
40
  # COPY ./fine_tuned_model /app/fine_tuned_model # 필요시 주석 해제
41
 
42
+ # 6. 환경 변수 설정
 
 
 
43
  ENV JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64
44
+ ENV HF_HOME=/app/.cache/huggingface
45
+ ENV HF_HUB_CACHE=/app/.cache/huggingface/hub
46
+ ENV TRANSFORMERS_CACHE=/app/.cache/huggingface/transformers
47
+ ENV SENTENCE_TRANSFORMERS_HOME=/app/.cache/huggingface/sentence_transformers
48
+ ENV PYTHONPATH=/app # 애플리케이션이 /app 디렉토리에서 모듈을 찾도록
49
  # ENV PYTHONUNBUFFERED=1 # 로그 즉시 확인 등에 유용
50
  # ENV PROJECT_ROOT=/app
51
+
 
 
 
 
 
52
  # 7. 실행할 포트 설정
53
  EXPOSE 7860
54
 
55
  # 8. 애플리케이션 실행 명령어
56
+ CMD ["uvicorn", "app.app:app", "--host", "0.0.0.0", "--port", "7860"]