Files
taxbaik/.gitea/workflows/deploy.yml
T
kjh2064 5ce44e3790
TaxBaik CI/CD / build-and-deploy (push) Failing after 44s
배포 스크립트 개선: SIGKILL 강제 종료 및 안정적 대기 시간
근본 원인:
- 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>
2026-06-26 17:14:46 +09:00

113 lines
3.9 KiB
YAML

name: TaxBaik CI/CD
on:
push:
branches:
- master
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup .NET
uses: actions/setup-dotnet@v4
with:
dotnet-version: '10.0'
- name: Restore dependencies
run: dotnet restore TaxBaik.sln
- name: Build solution
run: dotnet build TaxBaik.sln -c Release --no-restore
- name: Publish Web
run: dotnet publish TaxBaik.Web/ -c Release -o ./publish/web
- name: Publish Admin
run: dotnet publish TaxBaik.Admin/ -c Release -o ./publish/admin
- name: Copy migrations to publish
run: |
cp -r db/migrations ./publish/web/migrations || true
cp -r db/migrations ./publish/admin/migrations || true
- name: Generate build info
run: |
COMMIT_HASH=$(git rev-parse --short HEAD)
BUILD_TIME=$(date -u +'%Y-%m-%d %H:%M:%S UTC')
echo "COMMIT_HASH=$COMMIT_HASH" >> $GITHUB_ENV
echo "BUILD_TIME=$BUILD_TIME" >> $GITHUB_ENV
cat > ./publish/web/wwwroot/version.txt <<EOF
Version: $COMMIT_HASH
Built: $BUILD_TIME
EOF
cat > ./publish/admin/wwwroot/version.txt <<EOF
Version: $COMMIT_HASH
Built: $BUILD_TIME
EOF
- name: Setup SSH key
uses: webfactory/ssh-agent@v0.9.0
with:
ssh-private-key: ${{ secrets.DEPLOY_SSH_KEY }}
- name: Deploy Web
run: |
WEB_TIMESTAMP=$(date +%Y%m%d_%H%M%S)
mkdir -p ~/.ssh
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 }} /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
# 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
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 }} /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
# 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
EOF