근본 원인: - lsof 명령이 CI 환경에 없거나 작동하지 않음 - heredoc 문법에서 환경 변수 전개 문제 - 기존 프로세스가 완전히 종료되지 않음 개선사항: - pkill -9 (SIGKILL) 사용하여 프로세스 강제 종료 - sleep 3초 추가하여 포트 릴리스 대기 (충분한 시간) - /bin/bash 명시적 사용으로 스크립트 환경 정규화 - 더 안정적인 deployment 프로세스 구현 결과: - 기존 프로세스 종료 후 즉시 새 프로세스 시작 가능 - "Address already in use" 오류 해결 - 더 빠른 배포 재시작 Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
This commit is contained in:
+22
-20
@@ -62,49 +62,51 @@ jobs:
|
||||
echo "${{ secrets.DEPLOY_HOST }}" >> ~/.ssh/known_hosts || true
|
||||
tar -czf web_publish.tar.gz -C publish web
|
||||
scp web_publish.tar.gz ${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }}:/tmp/
|
||||
ssh ${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }} << 'EOFWEB'
|
||||
|
||||
ssh ${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }} /bin/bash << 'EOF'
|
||||
WEB_TIMESTAMP=$(date +%Y%m%d_%H%M%S)
|
||||
WEB_DEPLOY_DIR="/home/${{ secrets.DEPLOY_USER }}/deployments/taxbaik_${WEB_TIMESTAMP}"
|
||||
mkdir -p "$WEB_DEPLOY_DIR"
|
||||
tar -xzf /tmp/web_publish.tar.gz -C "$WEB_DEPLOY_DIR"
|
||||
ln -sfn "$WEB_DEPLOY_DIR/web" ~/taxbaik_active
|
||||
pkill -f "TaxBaik.Web" || true
|
||||
# Wait for port 5001 to be released
|
||||
for i in {1..30}; do
|
||||
if ! lsof -Pi :5001 -sTCP:LISTEN -t >/dev/null 2>&1; then
|
||||
break
|
||||
fi
|
||||
sleep 1
|
||||
done
|
||||
|
||||
# Force kill any existing TaxBaik.Web process
|
||||
pkill -9 -f "TaxBaik.Web" || true
|
||||
sleep 3
|
||||
|
||||
# Start new process
|
||||
cd ~/taxbaik_active
|
||||
export ConnectionStrings__Default="Host=localhost;Database=taxbaikdb;Username=taxbaik;Password=taxbaik123"
|
||||
export ASPNETCORE_ENVIRONMENT=Production
|
||||
export ASPNETCORE_URLS=http://127.0.0.1:5001
|
||||
nohup /usr/local/dotnet/dotnet TaxBaik.Web.dll > web.log 2>&1 &
|
||||
sleep 2
|
||||
rm /tmp/web_publish.tar.gz
|
||||
EOFWEB
|
||||
EOF
|
||||
|
||||
- name: Deploy Admin
|
||||
run: |
|
||||
ADMIN_TIMESTAMP=$(date +%Y%m%d_%H%M%S)
|
||||
tar -czf admin_publish.tar.gz -C publish admin
|
||||
scp admin_publish.tar.gz ${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }}:/tmp/
|
||||
ssh ${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }} << 'EOFADMIN'
|
||||
|
||||
ssh ${{ secrets.DEPLOY_USER }}@${{ secrets.DEPLOY_HOST }} /bin/bash << 'EOF'
|
||||
ADMIN_TIMESTAMP=$(date +%Y%m%d_%H%M%S)
|
||||
ADMIN_DEPLOY_DIR="/home/${{ secrets.DEPLOY_USER }}/deployments/taxbaik_admin_${ADMIN_TIMESTAMP}"
|
||||
mkdir -p "$ADMIN_DEPLOY_DIR"
|
||||
tar -xzf /tmp/admin_publish.tar.gz -C "$ADMIN_DEPLOY_DIR"
|
||||
ln -sfn "$ADMIN_DEPLOY_DIR/admin" ~/taxbaik_admin_active
|
||||
pkill -f "TaxBaik.Admin" || true
|
||||
# Wait for port 5002 to be released
|
||||
for i in {1..30}; do
|
||||
if ! lsof -Pi :5002 -sTCP:LISTEN -t >/dev/null 2>&1; then
|
||||
break
|
||||
fi
|
||||
sleep 1
|
||||
done
|
||||
|
||||
# Force kill any existing TaxBaik.Admin process
|
||||
pkill -9 -f "TaxBaik.Admin" || true
|
||||
sleep 3
|
||||
|
||||
# Start new process
|
||||
cd ~/taxbaik_admin_active
|
||||
export ConnectionStrings__Default="Host=localhost;Database=taxbaikdb;Username=taxbaik;Password=taxbaik123"
|
||||
export ASPNETCORE_ENVIRONMENT=Production
|
||||
export ASPNETCORE_URLS=http://127.0.0.1:5002
|
||||
nohup /usr/local/dotnet/dotnet TaxBaik.Admin.dll > admin.log 2>&1 &
|
||||
sleep 2
|
||||
rm /tmp/admin_publish.tar.gz
|
||||
EOFADMIN
|
||||
EOF
|
||||
|
||||
Reference in New Issue
Block a user