101 lines
3.3 KiB
Docker
101 lines
3.3 KiB
Docker
# 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"]
|
|
|