[FEAT] 重構 CI/CD 工作流並修正容器端口配置以對齊 Demo 環境
All checks were successful
Star-Cloud-Deploy-Demo / deploy-demo (push) Successful in 50s

This commit is contained in:
2026-03-06 16:49:13 +08:00
parent 74b6c71c95
commit acc81b2156
2 changed files with 35 additions and 134 deletions

View File

@@ -1,21 +1,18 @@
name: Star-Cloud-Deploy-System name: Star-Cloud-Deploy-Demo
on: on:
push: push:
branches: branches:
- demo - demo
- main
jobs: jobs:
# --- 1. Demo 環境部署 (103 本機) ---
deploy-demo: deploy-demo:
if: github.ref == 'refs/heads/demo'
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout Code - name: Checkout Code
uses: actions/checkout@v3 uses: actions/checkout@v3
with: with:
github-server-url: http://192.168.0.103:3000 github-server-url: https://gitea.taiwan-star.com.tw
repository: ${{ github.repository }} repository: ${{ github.repository }}
- name: Step 1 - Push Code to Demo - name: Step 1 - Push Code to Demo
@@ -31,168 +28,72 @@ jobs:
--exclude='storage' \ --exclude='storage' \
--exclude='.env' \ --exclude='.env' \
--exclude='public/build' \ --exclude='public/build' \
-e "ssh -i ~/.ssh/id_rsa_demo -o StrictHostKeyChecking=no" \ -e "ssh -p 2227 -i ~/.ssh/id_rsa_demo -o StrictHostKeyChecking=no" \
./ amba@192.168.0.103:/home/amba/star-cloud/ ./ root@220.132.7.82:/var/www/star-cloud-demo/
rm ~/.ssh/id_rsa_demo rm ~/.ssh/id_rsa_demo
# 2. 檢查是否需要重建容器(只有 Dockerfile 或 compose.yaml 變動時才重建)
- name: Step 2 - Check if Rebuild Needed - name: Step 2 - Check if Rebuild Needed
id: check_rebuild id: check_rebuild
uses: appleboy/ssh-action@master uses: appleboy/ssh-action@master
with: with:
host: 192.168.0.103 host: 220.132.7.82
port: 22 port: 2227
username: amba username: root
key: ${{ secrets.DEMO_SSH_KEY }} key: ${{ secrets.DEMO_SSH_KEY }}
script: | script: |
cd /home/amba/star-cloud cd /var/www/star-cloud-demo
# 檢查最近的 commit 是否包含 Dockerfile 或 compose.yaml 的變更 if git diff --name-only HEAD~1 HEAD 2>/dev/null | grep -qE '(Dockerfile|compose\.yaml|compose\.demo\.yaml|docker-compose\.yaml)'; then
if git diff --name-only HEAD~1 HEAD 2>/dev/null | grep -qE '(Dockerfile|compose\.yaml|docker-compose\.yaml)'; then
echo "REBUILD_NEEDED=true" echo "REBUILD_NEEDED=true"
else else
echo "REBUILD_NEEDED=false" echo "REBUILD_NEEDED=false"
fi fi
# 3. 啟動或重建容器(根據檢查結果決定是否加 --build
- name: Step 3 - Container Up & Health Check - name: Step 3 - Container Up & Health Check
uses: appleboy/ssh-action@master uses: appleboy/ssh-action@master
with: with:
host: 192.168.0.103 host: 220.132.7.82
port: 22 port: 2227
username: amba username: root
key: ${{ secrets.DEMO_SSH_KEY }} key: ${{ secrets.DEMO_SSH_KEY }}
script: | script: |
cd /home/amba/star-cloud cd /var/www/star-cloud-demo
chown -R 1000:1000 . chown -R 1000:1000 .
# 檢查是否需要重建 if git diff --name-only HEAD~1 HEAD 2>/dev/null | grep -qE '(Dockerfile|compose\.yaml|compose\.demo\.yaml|docker-compose\.yaml)'; then
if git diff --name-only HEAD~1 HEAD 2>/dev/null | grep -qE '(Dockerfile|compose\.yaml|docker-compose\.yaml)'; then
echo "🔄 偵測到 Docker 相關檔案變更,執行完整重建..." echo "🔄 偵測到 Docker 相關檔案變更,執行完整重建..."
WWWGROUP=1000 WWWUSER=1000 docker compose up -d --build --wait WWWGROUP=1000 WWWUSER=1000 docker compose -f compose.yaml -f compose.demo.yaml up -d --build --wait
else else
echo "⚡ 無 Docker 檔案變更,僅重載服務..." echo "⚡ 無 Docker 檔案變更,僅重載服務..."
# 確保容器正在運行(若未運行則啟動) if ! docker ps --format '{{.Names}}' | grep -q 'star-cloud-demo-laravel'; then
if ! docker ps --format '{{.Names}}' | grep -q 'star-cloud-laravel'; then
echo "容器未運行,正在啟動..." echo "容器未運行,正在啟動..."
WWWGROUP=1000 WWWUSER=1000 docker compose up -d --wait WWWGROUP=1000 WWWUSER=1000 docker compose -f compose.yaml -f compose.demo.yaml up -d --wait
else else
echo "容器已運行,跳過 docker compose直接進行程式碼部署..." echo "容器已運行,跳過 docker compose直接進行程式碼部署..."
fi fi
fi fi
echo "容器狀態:" && docker ps --filter "name=star-cloud-laravel" echo "容器狀態:" && docker ps --filter "name=star-cloud-demo"
- name: Step 4 - Composer & NPM Build - name: Step 4 - Composer & NPM Build
uses: appleboy/ssh-action@master uses: appleboy/ssh-action@master
with: with:
host: 192.168.0.103 host: 220.132.7.82
port: 22 port: 2227
username: amba username: root
key: ${{ secrets.DEMO_SSH_KEY }} key: ${{ secrets.DEMO_SSH_KEY }}
command_timeout: 10m
script: | script: |
cd /home/amba/star-cloud docker exec -u 1000:1000 -w /var/www/html star-cloud-demo-laravel sh -c "
docker exec -u 1000:1000 -w /var/www/html star-cloud-laravel sh -c " # 1. 後端依賴
# 1. 後端依賴 (Demo 環境建議加上 --no-interaction 避免卡住) composer install --no-dev --optimize-autoloader --no-interaction &&
composer install --no-dev --optimize-autoloader --no-interaction &&
# 2. 前端編譯
npm install &&
npm run build &&
# 3. Laravel 初始化與優化
php artisan migrate --force &&
php artisan optimize:clear &&
php artisan optimize &&
php artisan view:cache
"
docker exec star-cloud-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 }}
- name: Step 1 - Push Code to Production
run: |
apt-get update && apt-get install -y rsync openssh-client
mkdir -p ~/.ssh
echo "${{ secrets.PROD_SSH_KEY }}" > ~/.ssh/id_rsa_prod
chmod 600 ~/.ssh/id_rsa_prod
rsync -avz --delete \
--exclude='.git' \
--exclude='.env' \
--exclude='node_modules' \
--exclude='vendor' \
--exclude='public/build' \
-e "ssh -p 2224 -i ~/.ssh/id_rsa_prod -o StrictHostKeyChecking=no" \
./ root@erp.koori.tw:/var/www/star-cloud-prod/
rm ~/.ssh/id_rsa_prod
# 2. 檢查是否需要重建容器(只有 Dockerfile 或 compose.yaml 變動時才重建)
- name: Step 2 - Check if Rebuild Needed
id: check_rebuild_prod
uses: appleboy/ssh-action@master
with:
host: erp.koori.tw
port: 2224
username: root
key: ${{ secrets.PROD_SSH_KEY }}
script: |
cd /var/www/star-cloud-prod
# 檢查最近的 commit 是否包含 Dockerfile 或 compose.yaml 的變更
if git diff --name-only HEAD~1 HEAD 2>/dev/null | grep -qE '(Dockerfile|compose\.yaml|docker-compose\.yaml)'; then
echo "REBUILD_NEEDED=true"
else
echo "REBUILD_NEEDED=false"
fi
# 3. 啟動或重建容器(根據檢查結果決定是否加 --build
- name: Step 3 - Container Up & Health Check
uses: appleboy/ssh-action@master
with:
host: erp.koori.tw
port: 2224
username: root
key: ${{ secrets.PROD_SSH_KEY }}
script: |
cd /var/www/star-cloud-prod
chown -R 1000:1000 .
# 檢查是否需要重建 # 2. 前端編譯
if git diff --name-only HEAD~1 HEAD 2>/dev/null | grep -qE '(Dockerfile|compose\.yaml|docker-compose\.yaml)'; then npm install &&
echo "🔄 偵測到 Docker 相關檔案變更,執行完整重建..." npm run build &&
WWWGROUP=1000 WWWUSER=1000 docker compose up -d --build --wait
else
echo "⚡ 無 Docker 檔案變更,僅重載服務..."
# 確保容器正在運行(若未運行則啟動)
if ! docker ps --format '{{.Names}}' | grep -q 'star-cloud-laravel'; then
echo "容器未運行,正在啟動..."
WWWGROUP=1000 WWWUSER=1000 docker compose up -d --wait
else
echo "容器已運行,跳過 docker compose直接進行程式碼部署..."
fi
fi
echo "容器狀態:" && docker ps --filter "name=star-cloud-laravel" # 3. Laravel 初始化與優化
php artisan migrate --force &&
docker exec -u 1000:1000 -w /var/www/html star-cloud-laravel sh -c " php artisan optimize:clear &&
composer install --no-dev --optimize-autoloader && php artisan optimize &&
npm install && php artisan view:cache
npm run build "
docker exec star-cloud-demo-laravel chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache
php artisan migrate --force &&
php artisan optimize:clear &&
php artisan optimize &&
php artisan view:cache
"
docker exec star-cloud-laravel chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache

View File

@@ -11,7 +11,7 @@ services:
extra_hosts: extra_hosts:
- 'host.docker.internal:host-gateway' - 'host.docker.internal:host-gateway'
ports: ports:
- '${APP_PORT:-80}:80' - '${APP_PORT:-80}:8080'
- '${VITE_PORT:-5173}:${VITE_PORT:-5173}' - '${VITE_PORT:-5173}:${VITE_PORT:-5173}'
environment: environment:
WWWUSER: '${WWWUSER}' WWWUSER: '${WWWUSER}'