uuu
All checks were successful
Koori-ERP-Demo-Deploy / sync-update (push) Successful in 1m30s

This commit is contained in:
2026-01-05 22:18:47 +08:00
parent a6112b8a65
commit ca34636246

View File

@@ -49,37 +49,91 @@
# - name: 5. restart container
# run: |
# docker restart koori-erp-laravel
# name: Koori-ERP-Demo-Deploy
# on:
# push:
# branches:
# - main
# jobs:
# sync-update:
# runs-on: demo-server
# steps:
# - name: 1. Checkout New Code
# run: |
# rm -rf ./*
# git clone -b main http://server:3000/${{ gitea.repository }}.git .
# - name: 2. Stop Container First
# run: |
# # 先停止容器
# docker compose down || true
# - name: 3. Prepare Environment
# run: |
# # 建立 .env在宿主機
# cp .env.example .env
# sed -i "s|APP_KEY=.*|APP_KEY=${{ secrets.APP_KEY }}|g" .env
# - name: 4. Start Container (Files Already Ready)
# run: |
# # 啟動容器(檔案已經準備好,透過 volume 自動掛載)
# docker compose up -d --build --force-recreate --wait
# tar --exclude='.git' --exclude='node_modules' --exclude='vendor' -cf - . | docker exec -i koori-erp-laravel tar -xf - -C /var/www/html
# - name: 5. Backend & Frontend Build
# run: |
# docker exec -w /var/www/html koori-erp-laravel sh -c "
# composer install --optimize-autoloader &&
# npm install &&
# npm run build &&
# php artisan migrate --force &&
# php artisan optimize:clear
# "
# - name: 6. Final Permission Fix
# run: |
# docker exec koori-erp-laravel chown -R 1000:1000 /var/www/html
# docker exec koori-erp-laravel chmod -R 775 /var/www/html/storage
name: Koori-ERP-Demo-Deploy
on:
push:
branches:
- main
jobs:
sync-update:
runs-on: demo-server
runs-on: ubuntu-latest
steps:
- name: 1. Checkout New Code
run: |
rm -rf ./*
git clone -b main http://server:3000/${{ gitea.repository }}.git .
uses: actions/checkout@v3
with:
github-server-url: http://192.168.0.103:3000
repository: ${{ gitea.repository }}
# - name: 1. Checkout New Code
# run: |
# # 進入工作目錄並直接用 git 抓 code完全不需要 Node
# rm -rf ./*
# git clone -b main http://server:3000/${{ gitea.repository }}.git .
- name: 2. Stop Container First
- name: 2. Sync Files to Running Container
run: |
# ✅ 先停止容器
docker compose down || true
- name: 3. Prepare Environment
run: |
# ✅ 建立 .env在宿主機
# A. 執行複製
cp .env.example .env
sed -i "s|APP_KEY=.*|APP_KEY=${{ secrets.APP_KEY }}|g" .env
# B. 確保容器環境是最新的
# --wait 會確保容器真的跑起來了才執行下一步
docker compose -p koori-erp up -d --build --force-recreate --wait
- name: 4. Start Container (Files Already Ready)
run: |
# ✅ 啟動容器(檔案已經準備好,透過 volume 自動掛載)
docker compose up -d --build --force-recreate --wait
tar --exclude='.git' --exclude='node_modules' --exclude='vendor' -cf - . | docker exec -i koori-erp-laravel tar -xf - -C /var/www/html
- name: 5. Backend & Frontend Build
# C. 執行精簡化複製 (關鍵優化!)
# 排除 .git, node_modules, vendor 這三大黑洞
tar --exclude='.git' \
--exclude='node_modules' \
--exclude='vendor' \
-cf - . | docker exec -i koori-erp-laravel tar -xf - -C /var/www/html
- name: 3. Backend & Frontend Build
run: |
docker exec -w /var/www/html koori-erp-laravel sh -c "
composer install --optimize-autoloader &&
@@ -89,7 +143,8 @@ jobs:
php artisan optimize:clear
"
- name: 6. Final Permission Fix
- name: 4. Final Permission Fix
run: |
# 統一修正權限
docker exec koori-erp-laravel chown -R 1000:1000 /var/www/html
docker exec koori-erp-laravel chmod -R 775 /var/www/html/storage
docker exec koori-erp-laravel chmod -R 775 /var/www/html/storage /var/www/html/bootstrap/cache