This commit is contained in:
hiondal
2025-06-15 14:15:05 +00:00
parent d170dafd01
commit c7da54179b
7 changed files with 281 additions and 146 deletions
+37 -40
View File
@@ -1,5 +1,5 @@
# deployment/container/Dockerfile
# Poetry 기반 Vector DB API Service Image - PVC 마운트 충돌 해결
# Poetry 기반 Vector DB API Service Image - 홈 디렉토리 사용 (안전한 방식)
# Base Image에서 상속 (Poetry 환경 포함)
ARG BASE_IMAGE=vector-api-base:latest
@@ -7,66 +7,61 @@ FROM ${BASE_IMAGE}
# 메타데이터
LABEL maintainer="admin@example.com"
LABEL version="1.0.2"
LABEL description="Vector DB API Service with Poetry - PVC Mount Fixed"
LABEL version="1.0.3"
LABEL description="Vector DB API Service with Poetry - Home Directory Safe"
# 환경 변수 설정 - Poetry 가상환경 경로 유지
# 환경 변수 설정 - 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_VIRTUALENVS_PATH=/home/appuser/.cache/pypoetry/venvs \
POETRY_CACHE_DIR=/home/appuser/.cache/pypoetry/cache \
POETRY_NO_INTERACTION=1 \
PATH="/home/appuser/.local/bin:/opt/pypoetry/venvs/vector-api/bin:/usr/local/bin:/usr/bin:/bin"
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* /app/
COPY pyproject.toml poetry.lock* /home/appuser/
# 🚀 애플리케이션 소스 코드 복사
COPY app/ /app/app/
COPY app/ /home/appuser/app/
# 📦 Poetry 의존성 설치 (가상환경이 /opt에 생성됨)
RUN cd /app && \
# 📦 Poetry 의존성 설치 (가상환경이 홈 디렉토리에 생성됨)
RUN cd /home/appuser && \
# 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 && \
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 $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 mkdir -p /home/appuser/data /home/appuser/logs /home/appuser/vectordb \
&& chmod -R 755 /home/appuser/data /home/appuser/logs /home/appuser/vectordb
# 👤 사용자 및 권한 설정
RUN if id "appuser" &>/dev/null; then \
chown -R appuser:appuser /app; \
chown -R appuser:appuser /opt/pypoetry; \
else \
echo "appuser가 없어서 root로 실행됩니다"; \
fi
RUN chown -R appuser:appuser /home/appuser
# 🔧 실행 스크립트 생성 (Poetry 가상환경 자동 활성화)
RUN cat > /app/start.sh << 'EOF'
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 가상환경 정보:"
@@ -75,26 +70,28 @@ 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 /app/start.sh && \
chown appuser:appuser /app/start.sh
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 poetry run python -c "from dotenv import load_dotenv; import app.main; print('✅ 앱 헬스체크 성공')" || exit 1
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 /app
# 📁 작업 디렉토리 설정 (홈 디렉토리)
WORKDIR /home/appuser
# 👤 실행 사용자 설정
USER appuser
# 🎯 애플리케이션 실행 - 스크립트 사용
CMD ["/app/start.sh"]
CMD ["./start.sh"]
+20 -19
View File
@@ -19,9 +19,9 @@ ENV PYTHONDONTWRITEBYTECODE=1 \
POETRY_VIRTUALENVS_CREATE=true \
POETRY_VIRTUALENVS_PATH=/home/appuser/.cache/pypoetry/venvs \
POETRY_CACHE_DIR=/home/appuser/.cache/pypoetry/cache \
HF_HUB_CACHE=/app/.cache/huggingface \
TRANSFORMERS_CACHE=/app/.cache/transformers \
SENTENCE_TRANSFORMERS_HOME=/app/.cache/sentence_transformers
HF_HUB_CACHE=/home/appuser/.cache/huggingface \
TRANSFORMERS_CACHE=/home/appuser/.cache/transformers \
SENTENCE_TRANSFORMERS_HOME=/home/appuser/.cache/sentence_transformers
# 🔧 시스템 패키지 설치
RUN apt-get update && apt-get install -y --no-install-recommends \
@@ -86,36 +86,37 @@ RUN poetry --version && \
ls -la /home/appuser/.local/bin/poetry && \
which poetry
# 🏗️ 작업 디렉토리 설정 및 권한 조정
WORKDIR /app
# 🏗️ 작업 디렉토리 설정 (홈 디렉토리 사용)
WORKDIR /home/appuser
# root로 전환하여 디렉토리 소유권 설정
# 애플리케이션 디렉토리 생성
USER root
RUN chown -R appuser:appuser /app
RUN mkdir -p /home/appuser/app && \
chown -R appuser:appuser /home/appuser
# 📋 Poetry 설치 스크립트 복사 및 권한 설정
COPY setup.sh /app/setup.sh
RUN chmod +x /app/setup.sh && \
chown appuser:appuser /app/setup.sh
COPY setup.sh /home/appuser/setup.sh
RUN chmod +x /home/appuser/setup.sh && \
chown appuser:appuser /home/appuser/setup.sh
# appuser로 전환하여 Poetry 환경 설정
USER appuser
# 🚀 Poetry 환경 설정 및 의존성 설치
RUN cd /app && \
RUN cd /home/appuser && \
export DEBIAN_FRONTEND=noninteractive && \
./setup.sh --skip-poetry-install --skip-python311-check --force-reinstall
# 🗂️ 필요한 디렉토리 생성 및 권한 설정
USER root
RUN mkdir -p /app/.cache/huggingface \
/app/.cache/transformers \
/app/.cache/sentence_transformers \
/app/vectordb \
/app/data \
/app/logs && \
chmod -R 755 /app/.cache /app/vectordb /app/data /app/logs && \
chown -R appuser:appuser /app && \
RUN mkdir -p /home/appuser/.cache/huggingface \
/home/appuser/.cache/transformers \
/home/appuser/.cache/sentence_transformers \
/home/appuser/vectordb \
/home/appuser/data \
/home/appuser/logs && \
chmod -R 755 /home/appuser/.cache /home/appuser/vectordb /home/appuser/data /home/appuser/logs && \
chown -R appuser:appuser /home/appuser && \
# Poetry 가상환경 디렉토리 권한 재확인
chown -R appuser:appuser /home/appuser/.cache && \
chmod -R 755 /home/appuser/.cache