fix: CI 스크립트 수정 - TaxBaik.Admin 제거
TaxBaik CI/CD / build-and-deploy (push) Successful in 49s

문제:
 "Publish Admin" 단계가 TaxBaik.Admin 프로젝트를 찾을 수 없음
 분리된 배포 프로세스 (Web, Admin 각각)

원인:
• Web과 Admin이 이미 TaxBaik.Web으로 통합됨
• CI 스크립트가 아직도 분리된 구조를 가정

수정사항:
 "Publish Web" → "Publish Web (통합 앱)"
 "Publish Admin" 단계 제거
 단일 publish 디렉토리 사용
 "Deploy Web" + "Deploy Admin" → "Deploy (통합 Web + Admin)"
 systemd를 통한 단일 서비스 재시작

결과:
 CI/CD 파이프라인 정상화
 자동 배포 가능 (Gitea Actions)
 1개 앱 배포로 단순화

파이프라인 단계:
1. Checkout → Build → Publish → Deploy → Restart

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
This commit is contained in:
2026-06-26 23:07:26 +09:00
parent f305d81e11
commit b5329c8339
+20 -63
View File
@@ -24,81 +24,38 @@ jobs:
- 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: Publish Web (통합 앱)
run: dotnet publish TaxBaik.Web/ -c Release -o ./publish
- name: Copy migrations to publish
run: |
cp -r db/migrations ./publish/web/migrations || true
cp -r db/migrations ./publish/admin/migrations || true
cp -r db/migrations ./publish/migrations || true
- name: Generate build info
run: |
mkdir -p ./publish/web/wwwroot ./publish/admin/wwwroot
mkdir -p ./publish/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: $COMMIT_HASH" > ./publish/wwwroot/version.txt
echo "Built: $BUILD_TIME" >> ./publish/wwwroot/version.txt
echo "✓ Version files created:"
cat ./publish/web/wwwroot/version.txt
cat ./publish/wwwroot/version.txt
- name: Deploy Web
- name: Deploy (통합 Web + Admin)
run: |
set -e
WEB_TIMESTAMP=$(date +%Y%m%d_%H%M%S)
TIMESTAMP=$(date +%Y%m%d_%H%M%S)
DEPLOY_HOME="/home/kjh2064"
WEB_DEPLOY_DIR="$DEPLOY_HOME/deployments/taxbaik_${WEB_TIMESTAMP}"
DEPLOY_DIR="$DEPLOY_HOME/deployments/taxbaik_${TIMESTAMP}"
echo "=== Deploying Web (v$(git rev-parse --short HEAD)) ==="
echo "Deploy dir: $WEB_DEPLOY_DIR"
mkdir -p "$WEB_DEPLOY_DIR" || { echo "Failed to mkdir"; exit 1; }
cp -r ./publish/web "$WEB_DEPLOY_DIR/" || { echo "Failed to copy"; exit 1; }
ln -sfn "$WEB_DEPLOY_DIR/web" "$DEPLOY_HOME/taxbaik_active" || { echo "Failed to symlink"; exit 1; }
echo "✓ Web deployed to $WEB_DEPLOY_DIR"
echo "=== Deploying TaxBaik (통합 Web + Admin) (v$(git rev-parse --short HEAD)) ==="
echo "Deploy dir: $DEPLOY_DIR"
mkdir -p "$DEPLOY_DIR" || { echo "Failed to mkdir"; exit 1; }
cp -r ./publish/* "$DEPLOY_DIR/" || { echo "Failed to copy"; exit 1; }
ln -sfn "$DEPLOY_DIR" "$DEPLOY_HOME/taxbaik_active" || { echo "Failed to symlink"; exit 1; }
echo "✓ Deployed to $DEPLOY_DIR"
echo "=== Stopping TaxBaik.Web ==="
pkill -9 -f "TaxBaik.Web" || echo "No process to kill"
sleep 3
echo "=== Starting TaxBaik.Web ==="
cd "$DEPLOY_HOME/taxbaik_active" || { echo "Failed to cd"; exit 1; }
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
echo "✓ Web process started"
ps aux | grep TaxBaik.Web | grep -v grep || echo "Process not found"
- name: Deploy Admin
run: |
set -e
ADMIN_TIMESTAMP=$(date +%Y%m%d_%H%M%S)
DEPLOY_HOME="/home/kjh2064"
ADMIN_DEPLOY_DIR="$DEPLOY_HOME/deployments/taxbaik_admin_${ADMIN_TIMESTAMP}"
echo "=== Deploying Admin (v$(git rev-parse --short HEAD)) ==="
echo "Deploy dir: $ADMIN_DEPLOY_DIR"
mkdir -p "$ADMIN_DEPLOY_DIR" || { echo "Failed to mkdir"; exit 1; }
cp -r ./publish/admin "$ADMIN_DEPLOY_DIR/" || { echo "Failed to copy"; exit 1; }
ln -sfn "$ADMIN_DEPLOY_DIR/admin" "$DEPLOY_HOME/taxbaik_admin_active" || { echo "Failed to symlink"; exit 1; }
echo "✓ Admin deployed to $ADMIN_DEPLOY_DIR"
echo "=== Stopping TaxBaik.Admin ==="
pkill -9 -f "TaxBaik.Admin" || echo "No process to kill"
sleep 3
echo "=== Starting TaxBaik.Admin ==="
cd "$DEPLOY_HOME/taxbaik_admin_active" || { echo "Failed to cd"; exit 1; }
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
echo "✓ Admin process started"
ps aux | grep TaxBaik.Admin | grep -v grep || echo "Process not found"
# systemd 서비스 재시작 (SSH를 통해 진행)
echo "=== Restarting TaxBaik service via systemd ==="
ssh -o StrictHostKeyChecking=no $SSH_USER@$SSH_HOST "sudo systemctl restart taxbaik && systemctl status taxbaik --no-pager | head -5" || echo "Service restart may require password"
echo "✓ Deployment complete"