73b1696b0a
为节点新增 auto_online 字段与后台同步任务, 仅对开启托管的节点按在线状态自动同步前台显示。 管理端补齐单节点与批量开关、列表标识与统计, 并在自动上线启用时禁用手动显隐切换。 后端新增定时命令、保存校验、批量更新支持、 数据库迁移与单元测试,保证托管逻辑可落地。
8.9 KiB
8.9 KiB
变更提案: admin-frontend-node-auto-online
元信息
类型: 新功能
方案类型: implementation
优先级: P1
状态: 已选定方案
创建: 2026-04-27
1. 需求
背景
节点管理页当前已经展示在线、离线、待同步和显隐状态,但 show 仍完全依赖管理员手动切换。用户希望增加“自动上线”能力:后台定时检测节点状态,对启用该能力的节点自动同步前台展示状态,节点离线时自动隐藏,节点在线时自动显示。
目标
- 在节点管理页新增“自动上线”开关。
- 只有开启“自动上线”的节点由后台自动改写
show;未开启的节点继续保持手动显隐控制。 - 后台定时根据现有
available_status/is_online判定自动同步show。 - 节点编辑、新建、列表展示和 API 类型定义同步支持该字段。
约束条件
时间约束: 本轮完成实现并执行可用验证
性能约束: 定时任务只处理开启 auto_online 的节点,避免全量无意义写库
兼容性约束: 默认 auto_online=false,避免升级后自动覆盖现有节点显隐状态
业务约束: 未开启自动上线的节点不得被后台任务改写 show
验收标准
v2_server新增auto_online字段,默认关闭,并在Server模型中正确 cast。- 管理端
save/update/batchUpdate接口能保存auto_online。 - 后台调度命令只同步
auto_online=1的节点:在线或待同步时show=1,离线时show=0。 - 节点管理表格和编辑弹窗展示/编辑“自动上线”开关,且不会破坏现有显隐开关、墙状态检测和筛选能力。
- 前端类型检查与构建通过;后端相关文件通过 PHP 语法检查。
2. 方案
技术方案
采用“独立字段 + 独立同步服务”方案:
- 数据层新增
v2_server.auto_online布尔字段,默认false。 Server模型增加auto_onlinecast 和文档注释。- 后端新增
ServerAutoOnlineService,集中处理auto_online节点的显示状态同步,避免把业务逻辑散落在 Controller 或 Console Command 中。 - 新增 Artisan 命令
sync:server-auto-online,由app/Console/Kernel.php每 5 分钟调度,并使用onOneServer()/withoutOverlapping()防止多实例重复写入。 - 管理端 API 扩展
save/update/batchUpdate参数,允许保存或批量切换auto_online。 - 管理端节点页在表格中展示自动托管状态,编辑弹窗基础信息区增加开关;批量修改弹窗增加可选批量设置。
影响范围
涉及模块:
- 数据库迁移: 增加 v2_server.auto_online 字段
- 节点模型: 增加字段 cast 与文档注释
- 节点管理 API: 保存、单点更新、批量更新支持 auto_online
- 后台调度: 新增自动同步服务、命令和定时任务
- 管理端前端: 类型、API payload、节点页、编辑弹窗、批量修改弹窗
- 知识库: 更新项目上下文和节点管理模块说明
预计变更文件: 12-16
风险评估
| 风险 | 等级 | 应对 |
|---|---|---|
| 开启自动上线后后台任务覆盖管理员手动显隐 | 中 | 仅 auto_online=1 的节点自动同步;UI 文案明确“自动托管前台显示” |
| 在线状态依赖缓存,缓存过期导致节点被隐藏 | 中 | 使用现有 available_status 语义,保持与节点列表在线状态一致;不引入新的检测标准 |
| 批量更新误操作影响多个节点 | 中 | 批量修改弹窗保持“字段启用后才更新”的模式,默认不更新 auto_online |
| 已有墙状态检测改动被覆盖 | 低 | 增量修改当前脏文件,不移除 gfw_check 相关类型、接口和 UI |
方案取舍
唯一方案理由: 独立字段语义清晰,定时同步服务可测试、可扩展,并且默认关闭能保护现有手动显隐行为。
放弃的替代路径:
- 复用 check:server 命令: 会把离线通知和展示同步耦合,且 1800 秒通知阈值与 300 秒在线状态阈值不一致。
- 写入 protocol_settings: 自动上线不是协议配置,会污染协议数据并增加查询和批量更新复杂度。
回滚边界: 可撤销前端开关、接口参数、同步命令和迁移;已开启 auto_online 后由任务改写过的 show 需要管理员按业务需要手动恢复。
3. 技术设计
架构设计
flowchart TD
A[节点心跳/上报缓存] --> B[Server.available_status]
B --> C[ServerAutoOnlineService]
C --> D{auto_online=1}
D -->|在线/待同步| E[show=1]
D -->|离线| F[show=0]
G[节点管理页] --> H[save/update/batchUpdate]
H --> I[v2_server.auto_online]
I --> C
API设计
POST server/manage/save
- 请求: 原节点保存 payload 增加
auto_online?: boolean - 响应: 沿用
ApiResponse<boolean>
POST server/manage/update
- 请求:
{ id: number, show?: 0|1, enabled?: boolean, machine_id?: number|null, auto_online?: boolean } - 响应: 沿用
ApiResponse<boolean>
POST server/manage/batchUpdate
- 请求: 原批量更新 payload 增加
auto_online?: boolean - 响应: 沿用
ApiResponse<boolean>
数据模型
| 字段 | 类型 | 说明 |
|---|---|---|
auto_online |
boolean | 是否允许后台根据节点在线状态自动同步 show |
4. 核心场景
场景: 自动上线节点在线
模块: 节点管理
条件: 节点 auto_online=1,available_status 为在线或待同步
行为: 调度命令执行自动同步
结果: 节点 show=1,用户侧可见
场景: 自动上线节点离线
模块: 节点管理
条件: 节点 auto_online=1,available_status 为离线
行为: 调度命令执行自动同步
结果: 节点 show=0,用户侧隐藏
场景: 手动节点不受影响
模块: 节点管理
条件: 节点 auto_online=0
行为: 调度命令执行自动同步
结果: 后台不改写该节点 show
5. 技术决策
admin-frontend-node-auto-online#D001: 自动上线使用独立字段与独立同步服务
日期: 2026-04-27
状态: 采纳
背景: 需要让后台自动同步节点展示状态,同时保留未开启节点的手动显隐控制。
选项分析:
| 选项 | 优点 | 缺点 |
|---|---|---|
| A: 独立字段 + 独立服务 | 语义清晰、可测试、默认关闭安全、后续可扩展 | 需要新增迁移和命令 |
B: 复用 check:server |
改动较少 | 阈值语义不一致,离线通知和显示同步耦合 |
C: 写入 protocol_settings |
避免迁移 | 污染协议配置,查询和批量更新复杂 |
| 决策: 选择方案 A | ||
| 理由: 自动上线是节点运营策略,不是协议配置或离线通知;独立字段和服务能把边界表达清楚。 | ||
| 影响: 数据库、节点模型、节点管理 API、调度命令和管理端节点 UI。 |
6. 验证策略
verifyMode: review-first
reviewerFocus:
- app/Services/ServerAutoOnlineService.php 的 show 同步边界
- app/Http/Controllers/V2/Admin/Server/ManageController.php 的 update/batchUpdate 参数兼容性
- admin-frontend/src/views/nodes/* 的现有墙状态检测与批量选择逻辑不回退
testerFocus:
- php -l 后端新增/修改 PHP 文件
- npm run build 管理端类型检查与构建
- 人工检查 auto_online 默认关闭,批量修改默认不覆盖
uiValidation: required
riskBoundary:
- 不执行数据库迁移到真实环境
- 不写生产数据
- 不移除现有未提交的墙状态检测相关改动
7. 成果设计
设计方向
- 美学基调: Apple 风格的运维控制台,黑白主节奏、低装饰、强信息密度;自动上线作为状态治理能力,不做营销化强调。
- 记忆点: 每行节点同时能看见“当前显示状态”和“是否自动托管”,管理员可以一眼区分手动控制与自动控制。
- 参考:
apple/DESIGN.md与现有NodesView.vue。
视觉要素
- 配色: 延续黑色 hero、白色表格面板和 Apple Blue
#0071e3作为自动托管强调色;在线/离线仍使用现有绿色/红色状态点。 - 字体: 沿用项目现有系统字体栈,不引入新字体,保证管理端一致性。
- 布局: 表格显隐列附近增加自动上线开关或标识,编辑弹窗基础信息的“节点状态”区域加入第三张开关卡片。
- 动效: 复用 Element Plus Switch loading 与当前
switch-shell动态反馈,避免新增噪音动效。 - 氛围: 克制透明浅底提示块,突出“自动托管”状态但不抢占节点名称和在线状态。
技术约束
- 可访问性: 开关必须有明确文本标签和辅助描述;不能只用颜色表达自动状态。
- 响应式: 表格保持现有横向滚动和断点行为;编辑弹窗开关卡片在窄屏下自然堆叠。