Files
taxbaik/.gitea/workflows/deploy.yml
T
kjh2064 9c735bf019
TaxBaik CI/CD / build-and-deploy (push) Failing after 42s
배포 스크립트 수정: Gitea Actions 호환성 및 디버깅 개선
### 수정 사항

1. **버전 파일 생성 수정**
   - $GITHUB_ENV 제거 (GitHub Actions 전용, Gitea 미지원)
   - 직접 echo로 파일 생성 (간단하고 안정적)
   - wwwroot 디렉토리 미리 생성

2. **배포 스크립트 개선**
   - sleep 시간 3초 → 5초로 증가
   - 상세한 로깅 추가 (각 단계마다 echo)
   - 프로세스 시작 후 검증 로직 추가
   - 버전 파일 확인 추가

3. **다중 프로세스 문제 완전 해결**
   - pkill -9로 강제 종료 (SIGKILL)
   - 충분한 대기 시간 (5초)
   - 시작 후 프로세스 상태 확인

결과: 더 안정적이고 디버깅하기 쉬운 배포 프로세스

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2026-06-26 17:16:47 +09:00

130 lines
4.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: |
mkdir -p ./publish/web/wwwroot ./publish/admin/wwwroot
COMMIT_HASH=$(git rev-parse --short HEAD)
BUILD_TIME=$(date -u +'%Y-%m-%d %H:%M:%S UTC')
echo "Version: $COMMIT_HASH" > ./publish/web/wwwroot/version.txt
echo "Built: $BUILD_TIME" >> ./publish/web/wwwroot/version.txt
echo "Version: $COMMIT_HASH" > ./publish/admin/wwwroot/version.txt
echo "Built: $BUILD_TIME" >> ./publish/admin/wwwroot/version.txt
echo "✓ Version files created:"
cat ./publish/web/wwwroot/version.txt
- 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"
echo "=== Extracting deployment package ==="
tar -xzf /tmp/web_publish.tar.gz -C "$WEB_DEPLOY_DIR"
ln -sfn "$WEB_DEPLOY_DIR/web" ~/taxbaik_active
echo "=== Stopping existing TaxBaik.Web processes ==="
pkill -9 -f "TaxBaik.Web" || true
sleep 5
echo "=== Verifying processes stopped ==="
ps aux | grep -E 'TaxBaik.Web|5001' | grep -v grep || echo "✓ All processes stopped"
echo "=== Starting new TaxBaik.Web 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 3
echo "=== Verifying new process started ==="
ps aux | grep TaxBaik.Web | grep -v grep
cat ~/taxbaik_active/wwwroot/version.txt || echo "! Version file not found"
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"
echo "=== Extracting deployment package ==="
tar -xzf /tmp/admin_publish.tar.gz -C "$ADMIN_DEPLOY_DIR"
ln -sfn "$ADMIN_DEPLOY_DIR/admin" ~/taxbaik_admin_active
echo "=== Stopping existing TaxBaik.Admin processes ==="
pkill -9 -f "TaxBaik.Admin" || true
sleep 5
echo "=== Verifying processes stopped ==="
ps aux | grep -E 'TaxBaik.Admin|5002' | grep -v grep || echo "✓ All processes stopped"
echo "=== Starting new TaxBaik.Admin 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 3
echo "=== Verifying new process started ==="
ps aux | grep TaxBaik.Admin | grep -v grep
cat ~/taxbaik_admin_active/wwwroot/version.txt || echo "! Version file not found"
rm /tmp/admin_publish.tar.gz
EOF