fix(deploy): 서비스 목록 변수화 + rsync 전 권한 확보 + healthcheck 전서비스 추가
- deploy.sh / deploy-nas.sh: 서비스 목록을 변수로 통합하여 누락 방지 - deploy-nas.sh: rsync 전 chmod u+rwX로 Docker root 소유 파일 권한 확보 - healthcheck.sh: music-lab, blog-lab, realestate-lab, agent-office 추가 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -5,6 +5,16 @@ set -euo pipefail
|
||||
exec 200>/tmp/deploy.lock
|
||||
flock -n 200 || { echo "Deploy already running, skipping"; exit 0; }
|
||||
|
||||
# ── 서비스 목록 (한 곳에서만 관리) ──
|
||||
# docker compose 서비스명 (deployer 제외 — 자기 자신을 재빌드하면 스크립트 중단)
|
||||
BUILD_TARGETS="backend travel-proxy stock-lab music-lab blog-lab realestate-lab agent-office frontend"
|
||||
# 컨테이너 이름 (고아 정리용)
|
||||
CONTAINER_NAMES="lotto-backend stock-lab music-lab blog-lab realestate-lab agent-office travel-proxy lotto-frontend"
|
||||
# 헬스체크 대상
|
||||
HEALTH_ENDPOINTS="backend stock-lab travel-proxy music-lab blog-lab realestate-lab agent-office"
|
||||
# data 디렉토리
|
||||
DATA_DIRS="music stock blog realestate agent-office"
|
||||
|
||||
# 1. 자동 감지: Docker 컨테이너 내부인가?
|
||||
if [ -d "/repo" ] && [ -d "/runtime" ]; then
|
||||
echo "Detected Docker Container environment."
|
||||
@@ -55,19 +65,20 @@ done
|
||||
bash "$SRC/scripts/deploy-nas.sh"
|
||||
|
||||
# ── data 디렉토리 보장 (볼륨 마운트 실패 방지) ──
|
||||
mkdir -p "$DST/data" "$DST/data/music" "$DST/data/stock" "$DST/data/blog" "$DST/data/realestate" "$DST/data/agent-office"
|
||||
mkdir -p "$DST/data"
|
||||
for d in $DATA_DIRS; do
|
||||
mkdir -p "$DST/data/$d"
|
||||
done
|
||||
|
||||
# ── 서비스 재빌드 (deployer 제외 — 자기 자신을 재빌드하면 스크립트 중단됨) ──
|
||||
# ── 서비스 재빌드 (deployer 제외) ──
|
||||
cd "$DST"
|
||||
|
||||
BUILD_TARGETS="backend travel-proxy stock-lab music-lab blog-lab realestate-lab agent-office frontend"
|
||||
|
||||
# 1) compose가 관리하는 컨테이너 정리 (deployer 제외)
|
||||
# 1) compose가 관리하는 컨테이너 정리
|
||||
docker compose stop $BUILD_TARGETS 2>/dev/null || true
|
||||
docker compose rm -f $BUILD_TARGETS 2>/dev/null || true
|
||||
|
||||
# 2) Synology NAS 고아 컨테이너(해시 prefix 포함) 추가 정리
|
||||
for cname in lotto-backend stock-lab music-lab blog-lab realestate-lab agent-office travel-proxy lotto-frontend; do
|
||||
for cname in $CONTAINER_NAMES; do
|
||||
docker rm -f "$cname" 2>/dev/null || true
|
||||
done
|
||||
|
||||
@@ -80,10 +91,9 @@ echo "Waiting for services to start..."
|
||||
sleep 5
|
||||
|
||||
HEALTH_OK=true
|
||||
# 컨테이너 내부에서는 서비스명 + 내부포트(8000)로 접근
|
||||
for endpoint in "http://backend:8000/health" "http://stock-lab:8000/health" "http://travel-proxy:8000/health" "http://music-lab:8000/health" "http://blog-lab:8000/health" "http://realestate-lab:8000/health" "http://agent-office:8000/health"; do
|
||||
if ! curl -sf --max-time 10 --retry 2 --retry-delay 3 "$endpoint" > /dev/null 2>&1; then
|
||||
echo "HEALTH_FAIL: $endpoint"
|
||||
for svc in $HEALTH_ENDPOINTS; do
|
||||
if ! curl -sf --max-time 10 --retry 2 --retry-delay 3 "http://$svc:8000/health" > /dev/null 2>&1; then
|
||||
echo "HEALTH_FAIL: http://$svc:8000/health"
|
||||
HEALTH_OK=false
|
||||
fi
|
||||
done
|
||||
|
||||
Reference in New Issue
Block a user