# deployment/container/Dockerfile # Poetry 기반 Vector DB API Service Image - PVC 마운트 충돌 해결 # Base Image에서 상속 (Poetry 환경 포함) ARG BASE_IMAGE=vector-api-base:latest FROM ${BASE_IMAGE} # 메타데이터 LABEL maintainer="admin@example.com" LABEL version="1.0.2" LABEL description="Vector DB API Service with Poetry - PVC Mount Fixed" # 환경 변수 설정 - Poetry 가상환경 경로 유지 ENV HOME=/home/appuser \ PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ POETRY_VENV_IN_PROJECT=false \ POETRY_VIRTUALENVS_CREATE=true \ POETRY_VIRTUALENVS_PATH=/opt/pypoetry/venvs \ POETRY_CACHE_DIR=/opt/pypoetry/cache \ POETRY_NO_INTERACTION=1 \ PATH="/home/appuser/.local/bin:/opt/pypoetry/venvs/vector-api/bin:/usr/local/bin:/usr/bin:/bin" # root로 전환 (파일 복사 및 권한 설정용) USER root # 🔧 Poetry 설정 파일들 복사 (의존성 정보) COPY pyproject.toml poetry.lock* /app/ # 🚀 애플리케이션 소스 코드 복사 COPY app/ /app/app/ # 📦 Poetry 의존성 설치 (가상환경이 /opt에 생성됨) RUN cd /app && \ # Poetry 설정 확인 및 재설정 poetry config virtualenvs.in-project false && \ poetry config virtualenvs.create true && \ poetry config virtualenvs.path /opt/pypoetry/venvs && \ poetry config cache-dir /opt/pypoetry/cache && \ echo "🔧 Poetry 설정 확인:" && \ poetry config --list && \ echo "📦 의존성 설치 시작..." && \ poetry install --no-dev --no-interaction && \ echo "✅ 의존성 설치 완료" && \ # 설치된 패키지 확인 poetry show | head -10 && \ # 가상환경 위치 확인 poetry env info && \ # 캐시 정리 rm -rf $POETRY_CACHE_DIR/cache && \ rm -rf /tmp/* # 📁 데이터 디렉토리 생성 및 권한 설정 RUN mkdir -p /app/data /app/logs /app/vectordb \ && chmod -R 755 /app/data /app/logs /app/vectordb # 👤 사용자 및 권한 설정 RUN if id "appuser" &>/dev/null; then \ chown -R appuser:appuser /app; \ chown -R appuser:appuser /opt/pypoetry; \ else \ echo "appuser가 없어서 root로 실행됩니다"; \ fi # 🔧 실행 스크립트 생성 (Poetry 가상환경 자동 활성화) RUN cat > /app/start.sh << 'EOF' #!/bin/bash echo "🚀 Vector API 시작 중..." echo "📍 현재 디렉토리: $(pwd)" echo "🐍 Python 위치: $(which python)" echo "📦 Poetry 위치: $(which poetry)" echo "🔧 Poetry 가상환경 정보:" poetry env info echo "📋 설치된 패키지 (일부):" poetry show | head -5 echo "🔍 dotenv 모듈 테스트:" poetry run python -c "from dotenv import load_dotenv; print('✅ dotenv 모듈 정상 로드')" echo "🚀 애플리케이션 실행..." exec poetry run python app/main.py EOF RUN chmod +x /app/start.sh && \ chown appuser:appuser /app/start.sh # 🏥 헬스체크 (의존성 확인 포함) HEALTHCHECK --interval=30s --timeout=15s --start-period=60s --retries=3 \ CMD poetry run python -c "from dotenv import load_dotenv; import app.main; print('✅ 앱 헬스체크 성공')" || exit 1 # 🚀 포트 노출 EXPOSE 8000 # 📁 작업 디렉토리 설정 WORKDIR /app # 👤 실행 사용자 설정 USER appuser # 🎯 애플리케이션 실행 - 스크립트 사용 CMD ["/app/start.sh"]