- Change all environments (local and NAS) to use SQLite database - Remove MariaDB dependency and complexity - Make database initialization optional in deployment script - Simplify deployment by using single database type across all environments 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
311 lines
9.0 KiB
Bash
311 lines
9.0 KiB
Bash
#!/bin/bash
|
||
|
||
# 시놀로지 NAS 자료실 배포 스크립트
|
||
# 사용법: ./deploy-to-nas.sh [nas-ip] [project-name] [password]
|
||
# 예시: ./deploy-to-nas.sh 119.64.1.86 jaryo mypassword
|
||
# 환경변수: NAS_PASS=mypassword ./deploy-to-nas.sh
|
||
|
||
# 기본 설정
|
||
NAS_IP="${1:-119.64.1.86}"
|
||
PROJECT_NAME="${2:-jaryo}"
|
||
NAS_USER="vibsin9322"
|
||
# NAS_PASS 우선순위: 환경변수 > 스크립트 3번째 인자 > 프롬프트 방식
|
||
if [ -n "$3" ]; then
|
||
NAS_PASS="$3"
|
||
else
|
||
NAS_PASS="${NAS_PASS:-}"
|
||
fi
|
||
DEPLOY_DIR="/volume1/web/$PROJECT_NAME"
|
||
SERVICE_PORT="3005"
|
||
GITEA_URL="http://$NAS_IP:3000/vibsin9322/jaryo.git"
|
||
|
||
# SSH 명령어 준비 (NAS_PASS가 있으면 plink로 비대화식, 없으면 ssh 프롬프트)
|
||
if [ -n "$NAS_PASS" ]; then
|
||
SSH_CMD="plink -P 2222 -batch -pw \"$NAS_PASS\" $NAS_USER@$NAS_IP"
|
||
else
|
||
SSH_CMD="ssh -p 2222 -o ConnectTimeout=10 -o StrictHostKeyChecking=no $NAS_USER@$NAS_IP"
|
||
fi
|
||
|
||
echo "=========================================="
|
||
echo "🚀 시놀로지 NAS 자료실 배포 시작"
|
||
echo "=========================================="
|
||
echo "NAS IP: $NAS_IP"
|
||
echo "프로젝트: $PROJECT_NAME"
|
||
echo "배포 경로: $DEPLOY_DIR"
|
||
echo "서비스 포트: $SERVICE_PORT"
|
||
echo "Gitea URL: $GITEA_URL"
|
||
echo "=========================================="
|
||
|
||
# 사전 요구사항 확인
|
||
echo "📋 1단계: 사전 요구사항 확인"
|
||
|
||
# SSH 방식 확인
|
||
if [ -n "$NAS_PASS" ]; then
|
||
echo "🔧 SSH 접속 방식: 비밀번호 비대화식(plink)"
|
||
else
|
||
echo "🔧 SSH 접속 방식: 비밀번호 프롬프트 방식"
|
||
echo "📝 SSH 연결 시 비밀번호 입력이 필요합니다."
|
||
fi
|
||
|
||
# SSH 연결 테스트 (포트 2222)
|
||
echo "🔗 SSH 연결 테스트 중... (사용자: $NAS_USER, 포트: 2222)"
|
||
if ! eval "$SSH_CMD 'echo SSH 연결 성공'"; then
|
||
echo "❌ SSH 연결 실패. 다음을 확인하세요:"
|
||
echo " - NAS IP 주소: $NAS_IP"
|
||
echo " - SSH 포트: 2222"
|
||
echo " - SSH 서비스 활성화 (DSM > 제어판 > 터미널 및 SNMP)"
|
||
echo " - 방화벽 설정 (포트 2222 허용)"
|
||
exit 1
|
||
fi
|
||
echo "✅ SSH 연결 성공"
|
||
|
||
# Node.js 설치 확인
|
||
echo "📦 Node.js 설치 확인 중..."
|
||
NODE_PATH=""
|
||
if eval "$SSH_CMD 'test -f /usr/local/bin/node'" 2>/dev/null; then
|
||
NODE_PATH="/usr/local/bin"
|
||
elif eval "$SSH_CMD 'which node'" >/dev/null 2>&1; then
|
||
NODE_PATH=$(eval "$SSH_CMD 'which node'" | dirname)
|
||
else
|
||
echo "❌ Node.js가 설치되지 않았습니다."
|
||
echo "DSM 패키지 센터에서 Node.js를 설치하세요."
|
||
exit 1
|
||
fi
|
||
|
||
NODE_VERSION=$(eval "$SSH_CMD '$NODE_PATH/node --version'")
|
||
echo "✅ Node.js 설치됨: $NODE_VERSION ($NODE_PATH)"
|
||
|
||
# Git 설치 확인
|
||
echo "📦 Git 설치 확인 중..."
|
||
eval "$SSH_CMD 'which git'" >/dev/null 2>&1
|
||
if [ $? -ne 0 ]; then
|
||
echo "❌ Git이 설치되지 않았습니다."
|
||
echo "DSM 패키지 센터에서 Git Server를 설치하거나 다음 명령을 실행하세요:"
|
||
echo "ssh -p 2222 $NAS_USER@$NAS_IP 'sudo apt update && sudo apt install git'"
|
||
exit 1
|
||
fi
|
||
|
||
GIT_VERSION=$(eval "$SSH_CMD 'git --version'")
|
||
echo "✅ Git 설치됨: $GIT_VERSION"
|
||
|
||
# 2단계: 소스 코드 배포
|
||
echo ""
|
||
echo "📂 2단계: 소스 코드 배포"
|
||
|
||
# 기존 배포 디렉토리 확인
|
||
echo "🗂️ 배포 디렉토리 확인 중..."
|
||
eval "$SSH_CMD '
|
||
if [ -d '$DEPLOY_DIR' ]; then
|
||
echo '⚠️ 기존 배포가 존재합니다: $DEPLOY_DIR'
|
||
echo '백업 생성 중...'
|
||
sudo cp -r '$DEPLOY_DIR' '${DEPLOY_DIR}_backup_$(date +%Y%m%d_%H%M%S)'
|
||
echo '기존 배포 제거 중...'
|
||
sudo rm -rf '$DEPLOY_DIR'
|
||
fi
|
||
"
|
||
|
||
# 배포 디렉토리 생성
|
||
echo "📁 배포 디렉토리 생성 중..."
|
||
eval "$SSH_CMD '
|
||
sudo mkdir -p '$DEPLOY_DIR'
|
||
sudo chown admin:users '$DEPLOY_DIR'
|
||
cd '$DEPLOY_DIR'
|
||
"
|
||
|
||
# Git 클론
|
||
echo "📥 Gitea에서 소스 코드 클론 중..."
|
||
eval "$SSH_CMD '
|
||
cd '$DEPLOY_DIR'
|
||
git clone '$GITEA_URL' .
|
||
if [ \$? -ne 0 ]; then
|
||
echo '❌ Git 클론 실패'
|
||
exit 1
|
||
fi
|
||
echo '✅ 소스 코드 클론 완료'
|
||
"
|
||
|
||
# 3단계: 의존성 설치 및 빌드
|
||
echo ""
|
||
echo "🔧 3단계: 의존성 설치 및 빌드"
|
||
|
||
eval "$SSH_CMD '
|
||
cd '$DEPLOY_DIR'
|
||
|
||
# 기존 node_modules 제거
|
||
if [ -d 'node_modules' ]; then
|
||
echo '🗑️ 기존 node_modules 제거 중...'
|
||
rm -rf node_modules package-lock.json
|
||
fi
|
||
|
||
# 의존성 설치
|
||
echo '📦 의존성 설치 중...'
|
||
export PATH='$NODE_PATH':\$PATH
|
||
'$NODE_PATH'/npm install
|
||
|
||
if [ \$? -ne 0 ]; then
|
||
echo '❌ npm install 실패'
|
||
exit 1
|
||
fi
|
||
echo '✅ 의존성 설치 완료'
|
||
|
||
# 데이터베이스 초기화 (선택사항)
|
||
if [ "\$INIT_DB" = "true" ] && [ -f 'scripts/init-database.js' ]; then
|
||
echo '🗄️ SQLite 데이터베이스 초기화 중...'
|
||
echo 'ℹ️ SQLite 데이터베이스: data/jaryo.db'
|
||
|
||
export PATH='$NODE_PATH':\$PATH
|
||
if '$NODE_PATH'/npm run init-db; then
|
||
echo '✅ SQLite 초기화 완료'
|
||
else
|
||
echo '❌ SQLite 초기화 실패'
|
||
echo '💡 수동으로 초기화하려면:'
|
||
echo ' npm run init-db'
|
||
exit 1
|
||
fi
|
||
else
|
||
echo 'ℹ️ 데이터베이스 초기화 건너뜀 (INIT_DB=true로 설정시 초기화)'
|
||
fi
|
||
"
|
||
|
||
# 4단계: 서비스 설정
|
||
echo ""
|
||
echo "⚙️ 4단계: 서비스 설정"
|
||
|
||
# 시작 스크립트 생성
|
||
echo "📝 시작 스크립트 생성 중..."
|
||
eval "$SSH_CMD '
|
||
cat > '$DEPLOY_DIR/start-nas-service.sh' << 'EOF'
|
||
#!/bin/bash
|
||
|
||
# 자료실 NAS 서비스 시작 스크립트
|
||
PROJECT_DIR='$DEPLOY_DIR'
|
||
SERVICE_PORT='$SERVICE_PORT'
|
||
NODE_PATH='$NODE_PATH'
|
||
PID_FILE='\$PROJECT_DIR/jaryo-nas.pid'
|
||
LOG_FILE='\$PROJECT_DIR/logs/app.log'
|
||
|
||
# 로그 디렉토리 생성
|
||
mkdir -p '\$PROJECT_DIR/logs'
|
||
|
||
# 기존 프로세스 확인 및 종료
|
||
if [ -f '\$PID_FILE' ]; then
|
||
OLD_PID=\$(cat '\$PID_FILE')
|
||
if kill -0 '\$OLD_PID' 2>/dev/null; then
|
||
echo '기존 서비스 종료 중... (PID: '\$OLD_PID')'
|
||
kill '\$OLD_PID'
|
||
sleep 2
|
||
fi
|
||
rm -f '\$PID_FILE'
|
||
fi
|
||
|
||
# 포트 사용 확인
|
||
if netstat -tulpn | grep :'$SERVICE_PORT' >/dev/null; then
|
||
echo '⚠️ 포트 '$SERVICE_PORT'가 이미 사용 중입니다.'
|
||
echo '사용 중인 프로세스:'
|
||
netstat -tulpn | grep :'$SERVICE_PORT'
|
||
exit 1
|
||
fi
|
||
|
||
# 서비스 시작
|
||
echo '🚀 자료실 서비스 시작 중...'
|
||
cd '\$PROJECT_DIR'
|
||
# NAS 환경 변수 설정 (SQLite 사용)
|
||
export NODE_ENV=production
|
||
export HOST=0.0.0.0
|
||
export PORT='$SERVICE_PORT'
|
||
nohup \$NODE_PATH/node server.js > '\$LOG_FILE' 2>&1 &
|
||
echo \$! > '\$PID_FILE'
|
||
|
||
sleep 2
|
||
|
||
# 시작 확인
|
||
if kill -0 \$(cat '\$PID_FILE') 2>/dev/null; then
|
||
echo '✅ 자료실 서비스 시작 완료!'
|
||
echo '📍 접속 URL: http://$NAS_IP:$SERVICE_PORT'
|
||
echo '📋 PID: '\$(cat '\$PID_FILE')
|
||
echo '📄 로그: '\$LOG_FILE'
|
||
else
|
||
echo '❌ 서비스 시작 실패'
|
||
echo '로그 확인:'
|
||
tail -20 '\$LOG_FILE'
|
||
exit 1
|
||
fi
|
||
EOF
|
||
|
||
chmod +x '$DEPLOY_DIR/start-nas-service.sh'
|
||
"
|
||
|
||
# 중지 스크립트 생성
|
||
echo "📝 중지 스크립트 생성 중..."
|
||
eval "$SSH_CMD '
|
||
cat > '$DEPLOY_DIR/stop-nas-service.sh' << 'EOF'
|
||
#!/bin/bash
|
||
|
||
# 자료실 NAS 서비스 중지 스크립트
|
||
PROJECT_DIR='$DEPLOY_DIR'
|
||
PID_FILE='\$PROJECT_DIR/jaryo-nas.pid'
|
||
|
||
if [ -f '\$PID_FILE' ]; then
|
||
PID=\$(cat '\$PID_FILE')
|
||
if kill -0 '\$PID' 2>/dev/null; then
|
||
echo '🛑 자료실 서비스 중지 중... (PID: '\$PID')'
|
||
kill '\$PID'
|
||
sleep 2
|
||
|
||
# 강제 종료 확인
|
||
if kill -0 '\$PID' 2>/dev/null; then
|
||
echo '⚡ 강제 종료 중...'
|
||
kill -9 '\$PID'
|
||
fi
|
||
|
||
rm -f '\$PID_FILE'
|
||
echo '✅ 자료실 서비스 중지 완료'
|
||
else
|
||
echo '⚠️ 프로세스가 이미 종료됨'
|
||
rm -f '\$PID_FILE'
|
||
fi
|
||
else
|
||
echo '⚠️ PID 파일이 없습니다. 수동으로 프로세스를 확인하세요.'
|
||
echo '실행 중인 Node.js 프로세스:'
|
||
ps aux | grep 'node.*server.js' | grep -v grep
|
||
fi
|
||
EOF
|
||
|
||
chmod +x '$DEPLOY_DIR/stop-nas-service.sh'
|
||
"
|
||
|
||
# 5단계: 서비스 시작
|
||
echo ""
|
||
echo "🎬 5단계: 서비스 시작"
|
||
|
||
eval "$SSH_CMD '$DEPLOY_DIR/start-nas-service.sh'"
|
||
|
||
# 6단계: 접속 테스트
|
||
echo ""
|
||
echo "🧪 6단계: 접속 테스트"
|
||
|
||
sleep 3
|
||
|
||
echo "🌐 서비스 상태 확인 중..."
|
||
if curl -s "http://$NAS_IP:$SERVICE_PORT" >/dev/null; then
|
||
echo "✅ 자료실 서비스 정상 작동!"
|
||
echo ""
|
||
echo "=========================================="
|
||
echo "🎉 배포 완료!"
|
||
echo "=========================================="
|
||
echo "📍 접속 URL: http://$NAS_IP:$SERVICE_PORT"
|
||
echo "🔧 관리자 URL: http://$NAS_IP:$SERVICE_PORT/admin"
|
||
echo "📂 배포 경로: $DEPLOY_DIR"
|
||
echo "📄 로그 파일: $DEPLOY_DIR/logs/app.log"
|
||
echo ""
|
||
echo "🔧 서비스 관리:"
|
||
echo " 시작: ssh -p 2222 $NAS_USER@$NAS_IP '$DEPLOY_DIR/start-nas-service.sh'"
|
||
echo " 중지: ssh -p 2222 $NAS_USER@$NAS_IP '$DEPLOY_DIR/stop-nas-service.sh'"
|
||
echo " 로그: ssh -p 2222 $NAS_USER@$NAS_IP 'tail -f $DEPLOY_DIR/logs/app.log'"
|
||
echo ""
|
||
echo "📱 브라우저에서 http://$NAS_IP:$SERVICE_PORT 접속하세요!"
|
||
else
|
||
echo "❌ 서비스 접속 실패"
|
||
echo "로그 확인:"
|
||
eval "$SSH_CMD 'tail -20 $DEPLOY_DIR/logs/app.log'"
|
||
fi |