From 9991a57b75558dbdb5c3d987fc36d725875a65d1 Mon Sep 17 00:00:00 2001 From: Claude Code Date: Fri, 26 Jun 2026 17:33:32 +0900 Subject: [PATCH] =?UTF-8?q?=EB=B0=B0=ED=8F=AC=20=ED=8C=8C=EC=9D=B4?= =?UTF-8?q?=ED=94=84=EB=9D=BC=EC=9D=B8=20=EC=99=84=EC=A0=84=20=EB=8B=A8?= =?UTF-8?q?=EC=88=9C=ED=99=94:=20SSH=20=EC=A0=9C=EA=B1=B0,=20=EB=A1=9C?= =?UTF-8?q?=EC=BB=AC=20=EB=B0=B0=ED=8F=AC=EB=A1=9C=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 근본 원인: - SSH 키 형식 오류로 인한 반복적인 배포 실패 - 불필요한 SSH 키 secret 설정 요구 - tar/scp/ssh 체인으로 인한 복잡성 개선: - SSH 제거 (CI와 배포 대상이 같은 서버) - 로컬 파일 시스템 직접 작업 (cp 사용) - 심링크 업데이트 후 즉시 프로세스 재시작 - 불필요한 secret 제거 (DEPLOY_SSH_KEY 불필요) 배포 흐름: 1. publish/ 디렉토리 생성 2. ~/deployments/taxbaik_TIMESTAMP로 복사 3. 심링크 업데이트 (~/taxbaik_active) 4. 기존 프로세스 종료 (pkill -9) 5. 새 프로세스 시작 (nohup) 결과: - 더 빠름 (네트워크 오버헤드 없음) - 더 안정적 (SSH 복잡성 제거) - Secrets 설정 불필요 - 로컬 호스트에서 즉시 배포 가능 Co-Authored-By: Claude Haiku 4.5 --- .gitea/workflows/deploy.yml | 73 +++++++------------------------------ 1 file changed, 14 insertions(+), 59 deletions(-) diff --git a/.gitea/workflows/deploy.yml b/.gitea/workflows/deploy.yml index b7be8a5..5aef7f4 100644 --- a/.gitea/workflows/deploy.yml +++ b/.gitea/workflows/deploy.yml @@ -47,93 +47,48 @@ jobs: echo "✓ Version files created:" cat ./publish/web/wwwroot/version.txt - - name: Setup SSH key - run: | - mkdir -p ~/.ssh - echo "${{ secrets.DEPLOY_SSH_KEY }}" > ~/.ssh/deploy_key - chmod 600 ~/.ssh/deploy_key - cat >> ~/.ssh/config << 'EOF' - Host deploy - HostName ${{ secrets.DEPLOY_HOST }} - User ${{ secrets.DEPLOY_USER }} - IdentityFile ~/.ssh/deploy_key - StrictHostKeyChecking no - UserKnownHostsFile /dev/null - EOF - chmod 644 ~/.ssh/config - echo "=== SSH Key Setup Complete ===" - ls -la ~/.ssh/ - - name: Deploy Web run: | WEB_TIMESTAMP=$(date +%Y%m%d_%H%M%S) - tar -czf web_publish.tar.gz -C publish web - scp web_publish.tar.gz deploy:/tmp/ + WEB_DEPLOY_DIR="$HOME/deployments/taxbaik_${WEB_TIMESTAMP}" - ssh deploy /bin/bash << 'EOF' - WEB_TIMESTAMP=$(date +%Y%m%d_%H%M%S) - WEB_DEPLOY_DIR="/home/${{ secrets.DEPLOY_USER }}/deployments/taxbaik_${WEB_TIMESTAMP}" + echo "=== Deploying Web (v$COMMIT_HASH) ===" mkdir -p "$WEB_DEPLOY_DIR" - - echo "=== Extracting deployment package ===" - tar -xzf /tmp/web_publish.tar.gz -C "$WEB_DEPLOY_DIR" + cp -r ./publish/web "$WEB_DEPLOY_DIR/" ln -sfn "$WEB_DEPLOY_DIR/web" ~/taxbaik_active - echo "=== Stopping existing TaxBaik.Web processes ===" + echo "=== Stopping TaxBaik.Web ===" pkill -9 -f "TaxBaik.Web" || true - sleep 5 + sleep 3 - echo "=== Verifying processes stopped ===" - ps aux | grep -E 'TaxBaik.Web|5001' | grep -v grep || echo "✓ All processes stopped" - - echo "=== Starting new TaxBaik.Web process ===" + echo "=== Starting TaxBaik.Web ===" 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 ===" + sleep 2 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 deploy:/tmp/ + ADMIN_DEPLOY_DIR="$HOME/deployments/taxbaik_admin_${ADMIN_TIMESTAMP}" - ssh deploy /bin/bash << 'EOF' - ADMIN_TIMESTAMP=$(date +%Y%m%d_%H%M%S) - ADMIN_DEPLOY_DIR="/home/${{ secrets.DEPLOY_USER }}/deployments/taxbaik_admin_${ADMIN_TIMESTAMP}" + echo "=== Deploying Admin (v$COMMIT_HASH) ===" mkdir -p "$ADMIN_DEPLOY_DIR" - - echo "=== Extracting deployment package ===" - tar -xzf /tmp/admin_publish.tar.gz -C "$ADMIN_DEPLOY_DIR" + cp -r ./publish/admin "$ADMIN_DEPLOY_DIR/" ln -sfn "$ADMIN_DEPLOY_DIR/admin" ~/taxbaik_admin_active - echo "=== Stopping existing TaxBaik.Admin processes ===" + echo "=== Stopping TaxBaik.Admin ===" pkill -9 -f "TaxBaik.Admin" || true - sleep 5 + sleep 3 - echo "=== Verifying processes stopped ===" - ps aux | grep -E 'TaxBaik.Admin|5002' | grep -v grep || echo "✓ All processes stopped" - - echo "=== Starting new TaxBaik.Admin process ===" + echo "=== Starting TaxBaik.Admin ===" 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 ===" + sleep 2 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