name: Koori-ERP-Deploy-System on: push: branches: - demo - main jobs: # --- 1. Demo 環境部署 (103 本機) --- deploy-demo: if: github.ref == 'refs/heads/demo' 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 }} - name: Deploy to 103 Demo run: | cp .env.example .env # 設定 Demo 專用的 Key sed -i "s|APP_KEY=.*|APP_KEY=${{ secrets.APP_KEY }}|g" .env docker compose up -d --build --wait # 同步檔案到容器內 tar --exclude='.git' --exclude='node_modules' --exclude='vendor' -cf - . | docker exec -i koori-erp-laravel tar -xf - -C /var/www/html docker exec koori-erp-laravel chown -R 1000:1000 /var/www/html docker exec -u 1000:1000 -w /var/www/html koori-erp-laravel sh -c "composer install && npm install && npm run build && php artisan migrate --force && php artisan optimize:clear" docker exec koori-erp-laravel chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache # --- 2. 正式環境部署 (erp.koori.tw:2224) --- deploy-production: 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: | # 注意:這裡的 -e 指定了 ssh port 2224 rsync -avz --delete \ --exclude='.git' \ --exclude='node_modules' \ --exclude='vendor' \ -e "ssh -p 2224 -o StrictHostKeyChecking=no" \ ./ root@erp.koori.tw:/var/www/koori-erp-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 # 1. 確保 .env 存在 (建議正式機手動維護 .env,不隨 git 連動) if [ ! -f .env ]; then cp .env.example .env; fi # 2. 啟動容器 docker compose up -d --build # 3. 執行 Laravel 正式環境優化流程 docker exec -u 1000:1000 koori-erp-laravel-prod sh -c " composer install --no-dev --optimize-autoloader && npm install && npm run build && php artisan migrate --force && php artisan config:cache && php artisan route:cache && php artisan view:cache "