d4168720ac
新增用户高级筛选、批量操作与更多行级动作,支持邮件、 CSV、封禁恢复、订单分配、邀请查看、流量记录与重置流量 增强节点管理页的分页、父子筛选、跨页勾选、批量修改与 单节点置顶,并补齐后端批量更新 host、group_ids、rate 修复订单佣金状态误判问题,新增真实佣金筛选与行级确认, 同时优化仪表盘排行悬浮详情展示 补充 admin-frontend 独立 Dockerfile、Caddy 配置与 GHCR 发布工作流,支持通过独立镜像部署管理前端
38 lines
2.6 KiB
Markdown
38 lines
2.6 KiB
Markdown
# admin-frontend GHCR 自动构建与 compose 接入 — 实施规划
|
||
|
||
## 目标与范围
|
||
- 让 `admin-frontend` 从“仓内前端目录”升级为“可独立构建、可独立分发、可独立部署”的静态前端镜像。
|
||
- 保持当前主应用镜像发布链路不变,同时补一条面向前端的独立 GHCR 发布通道。
|
||
- 让 `compose` 分支可直接拉起独立 `admin` 服务,对外暴露单独端口。
|
||
|
||
## 架构与实现策略
|
||
- 构建链路:
|
||
- 在 `admin-frontend/` 下新增独立 Dockerfile,采用 `Node -> Caddy` 多阶段构建。
|
||
- 通过环境变量把容器构建输出切到 `dist`,避免影响当前仓内 `public/assets/admin` 输出。
|
||
- 发布链路:
|
||
- 新增单独的 GitHub Actions workflow,仅在 `admin-frontend/**` 或 workflow 自身变更时触发。
|
||
- 镜像发布到 `ghcr.io/<owner>/xboard-admin-frontend`,标签策略与主应用保持一致:分支、sha、`new`、`latest`。
|
||
- 运行链路:
|
||
- 通过 Caddy 在容器内提供静态资源,根路径自动重定向到 `/assets/admin/`。
|
||
- `compose` 分支新增 `admin` 服务,直接拉取 GHCR 镜像并暴露 `7002:80`。
|
||
|
||
## 完成定义
|
||
- `admin-frontend` 本地可通过 Dockerfile 正常构建镜像。
|
||
- GitHub Actions 可在 push 后自动构建并推送 `admin-frontend` 镜像到 GHCR。
|
||
- `compose` 分支的 `compose.yaml` 已包含独立 `admin` 服务,且镜像名与端口配置正确。
|
||
- `npm run build` 与 workflow/compose 语法检查通过。
|
||
|
||
## 风险与验证
|
||
- 风险 1:`vite.config.ts` 目前默认输出到仓根 `public/assets/admin`,容器构建若不切换输出目录会污染镜像构建路径,因此必须引入可覆写输出目录。
|
||
- 风险 2:若前端服务直接暴露 `/` 而未处理 `/assets/admin/`,现有资源前缀会失配,因此需要容器内重定向和静态路径兜底。
|
||
- 风险 3:当前仓库已有大量未提交业务改动,不能直接切换分支修改 `compose.yaml`,需在独立 worktree 中处理 `compose` 分支文件。
|
||
- 验证方式:
|
||
- `npm run build`
|
||
- `docker build -f admin-frontend/Dockerfile admin-frontend`
|
||
- `python -c "import yaml; ..."` 检查 workflow 与 compose YAML
|
||
|
||
## 决策记录
|
||
- [2026-04-24] 采用独立 `admin` 服务,并按用户确认暴露单独端口,不内嵌回 Laravel 主服务容器。
|
||
- [2026-04-24] 采用独立 workflow,而不是把前端镜像构建塞进现有后端 `docker-publish.yml`,以降低耦合和回归面。
|
||
- [2026-04-24] 前端运行时采用 Caddy 提供静态资源并做 `/ -> /assets/admin/` 重定向,兼容当前 `base: '/assets/admin/'`。
|