重构:TopicProcessor 状态管理系统与 Reset 方法优化

新增功能:
- 添加 ProcessorState 状态类型(Idle/Starting/Running/Stopping/Stopped/Resetting/Error)
- 添加 ProcessorStatus 结构体和状态管理方法(GetState/GetStatus/setState)
- 实现状态转换逻辑和访问控制(CanWrite/CanQuery)
- 新增 CanReset() 方法检查是否可执行重置操作

Reset 方法优化:
- 重写 Reset() 方法,不再停止 processor
- 只有在无待处理记录时才能执行重置
- 进入 Resetting 状态期间阻止所有读写操作
- 重置后自动恢复到之前的运行状态
- 正确关闭并重置 cursor 和 stats 组件
- 调整执行顺序:先关闭组件,再删除文件,后重新初始化

错误处理增强:
- 添加 ErrProcessorResetting 和 ErrInvalidState 错误类型
- 添加 EventStateChanged 事件类型
- 修复 writer/index 为 nil 时的空指针问题

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
2025-10-04 18:56:52 +08:00
parent 810664eb12
commit bcc328b129
6 changed files with 303 additions and 71 deletions

View File

@@ -36,6 +36,12 @@ var (
// ErrInvalidConfig 表示配置无效
ErrInvalidConfig = errors.New("invalid config")
// ErrProcessorResetting 表示处理器正在重置中,操作被阻止
ErrProcessorResetting = errors.New("processor is resetting, operations blocked")
// ErrInvalidState 表示处理器状态无效,不允许执行该操作
ErrInvalidState = errors.New("invalid processor state for this operation")
)
// TopicError 表示与 topic 相关的错误