diff --git a/vector/deployment/container/Dockerfile b/vector/deployment/container/Dockerfile index fe195fa..6ad6f35 100644 --- a/vector/deployment/container/Dockerfile +++ b/vector/deployment/container/Dockerfile @@ -1,97 +1,26 @@ # deployment/container/Dockerfile -# Poetry 기반 Vector DB API Service Image - 홈 디렉토리 사용 (안전한 방식) - -# Base Image에서 상속 (Poetry 환경 포함) +# Vector DB API Service Image - 완전히 최소화된 버전 ARG BASE_IMAGE=vector-api-base:latest FROM ${BASE_IMAGE} # 메타데이터 LABEL maintainer="admin@example.com" -LABEL version="1.0.3" -LABEL description="Vector DB API Service with Poetry - Home Directory Safe" +LABEL version="1.0.6" +LABEL description="Vector DB API Service - 완전히 최소화 (권한 변경 불필요)" -# 환경 변수 설정 - Poetry 가상환경 경로 유지 (홈 디렉토리) -ENV HOME=/home/appuser \ - PYTHONDONTWRITEBYTECODE=1 \ - PYTHONUNBUFFERED=1 \ - POETRY_VENV_IN_PROJECT=false \ - POETRY_VIRTUALENVS_CREATE=true \ - POETRY_VIRTUALENVS_PATH=/home/appuser/.cache/pypoetry/venvs \ - POETRY_CACHE_DIR=/home/appuser/.cache/pypoetry/cache \ - POETRY_NO_INTERACTION=1 \ - PATH="/home/appuser/.local/bin:/home/appuser/.cache/pypoetry/venvs/vector-api/bin:/usr/local/bin:/usr/bin:/bin" - -# root로 전환 (파일 복사 및 권한 설정용) -USER root - -# 🔧 Poetry 설정 파일들 복사 (의존성 정보) -COPY pyproject.toml poetry.lock* /home/appuser/ - -# 🚀 애플리케이션 소스 코드 복사 -COPY app/ /home/appuser/app/ - -# 📦 Poetry 의존성 설치 (가상환경이 홈 디렉토리에 생성됨) -RUN cd /home/appuser && \ - # Poetry 설정 확인 및 재설정 - su - appuser -c "cd /home/appuser && \ - poetry config virtualenvs.in-project false && \ - poetry config virtualenvs.create true && \ - poetry config virtualenvs.path /home/appuser/.cache/pypoetry/venvs && \ - poetry config cache-dir /home/appuser/.cache/pypoetry/cache && \ - echo '🔧 Poetry 설정 확인:' && \ - poetry config --list && \ - echo '📦 의존성 설치 시작...' && \ - poetry install --no-dev --no-interaction && \ - echo '✅ 의존성 설치 완료' && \ - poetry show | head -10 && \ - poetry env info" && \ - # 캐시 정리 - rm -rf /tmp/* - -# 📁 데이터 디렉토리 생성 및 권한 설정 -RUN mkdir -p /home/appuser/data /home/appuser/logs /home/appuser/vectordb \ - && chmod -R 755 /home/appuser/data /home/appuser/logs /home/appuser/vectordb - -# 👤 사용자 및 권한 설정 -RUN chown -R appuser:appuser /home/appuser - -# 🔧 실행 스크립트 생성 (Poetry 가상환경 자동 활성화) -RUN cat > /home/appuser/start.sh << 'EOF' -#!/bin/bash -echo "🚀 Vector API 시작 중..." -echo "📍 현재 디렉토리: $(pwd)" -echo "👤 현재 사용자: $(whoami)" -echo "🏠 홈 디렉토리: $HOME" -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 "🔍 가상환경 위치 확인:" -ls -la ~/.cache/pypoetry/venvs/ -echo "🚀 애플리케이션 실행..." -exec poetry run python app/main.py -EOF - -RUN chmod +x /home/appuser/start.sh && \ - chown appuser:appuser /home/appuser/start.sh - -# 🏥 헬스체크 (의존성 확인 포함) -HEALTHCHECK --interval=30s --timeout=15s --start-period=60s --retries=3 \ - CMD su - appuser -c "cd /home/appuser && poetry run python -c 'from dotenv import load_dotenv; import app.main; print(\"✅ 앱 헬스체크 성공\")'" || exit 1 - -# 🚀 포트 노출 -EXPOSE 8000 - -# 📁 작업 디렉토리 설정 (홈 디렉토리) +# 작업 디렉토리 설정 (명확성과 안정성을 위해 명시적 선언) WORKDIR /home/appuser -# 👤 실행 사용자 설정 -USER appuser +# 🚀 애플리케이션 소스 코드 복사 (상대경로로 간단하게) +COPY app/ app/ -# 🎯 애플리케이션 실행 - 스크립트 사용 -CMD ["./start.sh"] +# 포트 노출 +EXPOSE 8000 + +# 헬스체크 +HEALTHCHECK --interval=30s --timeout=15s --start-period=60s --retries=3 \ + CMD poetry run python -c "import app.main; print('✅ 헬스체크 성공')" || exit 1 + +# 애플리케이션 실행 +CMD ["poetry", "run", "python", "app/main.py"]