mirror of
https://github.com/Awuqing/BackupX.git
synced 2026-05-06 20:02:41 +08:00
基础修复: - 新增节点离线检测:每 15s 扫描,超 45s 未心跳的远程节点自动置离线 - 节点删除前检查关联任务,避免孤立备份任务 - BackupTaskRepository 新增 CountByNodeID/ListByNodeID Master 端 Agent 协议: - 新增 AgentCommand 模型与命令队列仓储(pending/dispatched/succeeded/failed/timeout) - 新增 AgentService:任务下发、命令轮询、结果回收、超时扫描 - 新增专用 Agent HTTP API(X-Agent-Token 认证): /api/agent/heartbeat /api/agent/commands/poll /api/agent/commands/:id/result /api/agent/tasks/:id /api/agent/records/:id - BackupExecutionService 支持 node 路由:task.NodeID 指向远程节点时自动入队派发 Agent CLI(backupx agent 子命令): - 配置:YAML 文件 / 环境变量 / CLI 参数,优先级 CLI > 文件 > 环境 - 心跳循环 + 命令轮询循环 + 优雅退出 - 本地复用 BackupRunner 与 storage registry 执行备份并直接上传 - 支持 run_task 和 list_dir 两种命令 远程目录浏览: - NodeService 支持通过 Agent RPC 列出远程节点目录(15s 超时) 前端: - NodesPage 添加节点后展示 Agent 启动命令和环境变量配置 文档: - README 中英文重写"多节点集群"章节,含架构图、步骤、限制、CLI 参考
45 lines
2.0 KiB
Go
45 lines
2.0 KiB
Go
package model
|
||
|
||
import "time"
|
||
|
||
// AgentCommand 状态常量
|
||
const (
|
||
AgentCommandStatusPending = "pending" // 待 Agent 拉取
|
||
AgentCommandStatusDispatched = "dispatched" // Agent 已领取,正在执行
|
||
AgentCommandStatusSucceeded = "succeeded" // 执行成功
|
||
AgentCommandStatusFailed = "failed" // 执行失败
|
||
AgentCommandStatusTimeout = "timeout" // 超时未完成
|
||
)
|
||
|
||
// AgentCommand 类型常量
|
||
const (
|
||
// AgentCommandTypeRunTask 运行指定备份任务
|
||
// Payload: {"taskId": 123, "recordId": 456}
|
||
AgentCommandTypeRunTask = "run_task"
|
||
// AgentCommandTypeListDir 远程列目录(用于文件备份时的目录浏览器)
|
||
// Payload: {"path": "/var/log"}
|
||
// Result: {"entries": [{"name":"...", "path":"...", "isDir":true, "size":0}]}
|
||
AgentCommandTypeListDir = "list_dir"
|
||
)
|
||
|
||
// AgentCommand 代表 Master 发给某个 Agent 节点的待执行命令。
|
||
// 使用简单的数据库队列实现:Agent 通过 token 长轮询拉取本节点 pending 命令,
|
||
// 执行后回写状态与结果。Master 侧通过定时检查把超时的命令标记为 timeout。
|
||
type AgentCommand struct {
|
||
ID uint `gorm:"primaryKey" json:"id"`
|
||
NodeID uint `gorm:"column:node_id;index;not null" json:"nodeId"`
|
||
Type string `gorm:"size:32;index;not null" json:"type"`
|
||
Status string `gorm:"size:20;index;not null;default:'pending'" json:"status"`
|
||
Payload string `gorm:"type:text" json:"payload"` // JSON
|
||
Result string `gorm:"type:text" json:"result"` // JSON(成功结果)
|
||
ErrorMessage string `gorm:"column:error_message;type:text" json:"errorMessage"`
|
||
DispatchedAt *time.Time `gorm:"column:dispatched_at" json:"dispatchedAt,omitempty"`
|
||
CompletedAt *time.Time `gorm:"column:completed_at" json:"completedAt,omitempty"`
|
||
CreatedAt time.Time `json:"createdAt"`
|
||
UpdatedAt time.Time `json:"updatedAt"`
|
||
}
|
||
|
||
func (AgentCommand) TableName() string {
|
||
return "agent_commands"
|
||
}
|