diff --git a/.gitea/workflows/deploy.yaml b/.gitea/workflows/deploy.yaml index e72e34d..62f1161 100644 --- a/.gitea/workflows/deploy.yaml +++ b/.gitea/workflows/deploy.yaml @@ -35,56 +35,135 @@ jobs: if: github.ref == 'refs/heads/main' runs-on: ubuntu-latest steps: + # - name: Checkout Code + # uses: actions/checkout@v3 + # with: + # github-server-url: http://192.168.0.103:3000 + # repository: ${{ github.repository }} + + # # 使用 rsync 透過 2224 Port 推送代碼 + # - name: Push Code to Production + # run: | + # # 1. 快速安裝工具 + # apt-get update && apt-get install -y rsync openssh-client + + # # 2. 準備鑰匙 + # mkdir -p ~/.ssh + # echo "${{ secrets.PROD_SSH_KEY }}" > ~/.ssh/id_rsa_prod + # chmod 600 ~/.ssh/id_rsa_prod + + # # 3. 精簡後的同步指令 (只排除 .git) + # rsync -avz --delete \ + # --exclude='.git' \ + # --exclude='.env' \ + # -e "ssh -p 2224 -i ~/.ssh/id_rsa_prod -o StrictHostKeyChecking=no" \ + # ./ root@erp.koori.tw:/var/www/koori-erp-prod/ + + # rm ~/.ssh/id_rsa_prod + + + # # 遠端執行 Docker 指令 + # - name: Remote Docker Commands + # uses: appleboy/ssh-action@master + # with: + # host: erp.koori.tw + # port: 2224 # <--- 這裡指定了 2224 Port + # username: root + # key: ${{ secrets.PROD_SSH_KEY }} + # script: | + # cd /var/www/koori-erp-prod + # chown -R 1000:1000 . + + # # 2. 啟動容器 + # WWWGROUP=1000 WWWUSER=1000 docker compose up -d --build --wait + + # # 3. 執行 Laravel 正式環境優化流程 + # docker exec -u 1000:1000 -w /var/www/html koori-erp-laravel sh -c " + # composer install --no-dev --optimize-autoloader && + # npm install && + # npm run build && + # php artisan migrate --force && + # php artisan optimize:clear && + # php artisan optimize + # " + # docker exec koori-erp-laravel chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache + # docker restart koori-erp-laravel - name: Checkout Code uses: actions/checkout@v3 with: github-server-url: http://192.168.0.103:3000 repository: ${{ github.repository }} - - # 使用 rsync 透過 2224 Port 推送代碼 - - name: Push Code to Production + + - name: Step 1 - Push Code to Production run: | - # 1. 快速安裝工具 apt-get update && apt-get install -y rsync openssh-client - - # 2. 準備鑰匙 mkdir -p ~/.ssh echo "${{ secrets.PROD_SSH_KEY }}" > ~/.ssh/id_rsa_prod chmod 600 ~/.ssh/id_rsa_prod - - # 3. 精簡後的同步指令 (只排除 .git) rsync -avz --delete \ --exclude='.git' \ --exclude='.env' \ + --exclude='node_modules' \ + --exclude='vendor' \ -e "ssh -p 2224 -i ~/.ssh/id_rsa_prod -o StrictHostKeyChecking=no" \ ./ root@erp.koori.tw:/var/www/koori-erp-prod/ - rm ~/.ssh/id_rsa_prod - - # 遠端執行 Docker 指令 - - name: Remote Docker Commands + # 2. 啟動或重建容器(502 最容易發生在這裡的瞬間) + - name: Step 2 - Container Up & Health Check uses: appleboy/ssh-action@master with: host: erp.koori.tw - port: 2224 # <--- 這裡指定了 2224 Port + port: 2224 username: root key: ${{ secrets.PROD_SSH_KEY }} script: | cd /var/www/koori-erp-prod chown -R 1000:1000 . - - # 2. 啟動容器 WWWGROUP=1000 WWWUSER=1000 docker compose up -d --build --wait - - # 3. 執行 Laravel 正式環境優化流程 + echo "容器狀態:" && docker ps --filter "name=koori-erp-laravel" + + # 3. 處理後端與前端依賴(這時網站可能因為沒 vendor 呈現 500/502) + - name: Step 3 - Composer & NPM Build + uses: appleboy/ssh-action@master + with: + host: erp.koori.tw + port: 2224 + username: root + key: ${{ secrets.PROD_SSH_KEY }} + script: | docker exec -u 1000:1000 -w /var/www/html koori-erp-laravel sh -c " composer install --no-dev --optimize-autoloader && npm install && - npm run build && + npm run build + " + + # 4. 處理資料庫與 Laravel 快取 + - name: Step 4 - Database & Optimization + uses: appleboy/ssh-action@master + with: + host: erp.koori.tw + port: 2224 + username: root + key: ${{ secrets.PROD_SSH_KEY }} + script: | + docker exec -u 1000:1000 -w /var/www/html koori-erp-laravel sh -c " php artisan migrate --force && php artisan optimize:clear && - php artisan optimize + php artisan optimize && + php artisan view:cache " + + # 5. 最後權限修正與重啟(一發入魂,解決 502) + - name: Step 5 - Final Permission & Service Restart + uses: appleboy/ssh-action@master + with: + host: erp.koori.tw + port: 2224 + username: root + key: ${{ secrets.PROD_SSH_KEY }} + script: | docker exec koori-erp-laravel chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache - docker restart koori-erp-laravel \ No newline at end of file + echo "正在進行最後重啟以確保服務生效..." + docker restart koori-erp-laravel + echo "部署完成!" \ No newline at end of file