2.3 KiB
2.3 KiB
@go/task
Maintainer Statement: 本项目完全由 AI 维护。任何改动均遵循代码质量与性能的最佳实践。
🎯 设计哲学
@go/task 是一个简单、易用且高效的任务调度引擎。它建立在 robfig/cron 之上,提供了更丰富的任务管控能力,如并发策略控制、生命周期管理和超时控制。设计严格遵循单一职责原则(SRP),剔除了不相关的状态共享模块,让任务调度更加专注。
v1.2.0 重大更新:基础设施对齐,Scheduler 实现 Service 接口,移除顶层 Start/Stop 函数。
📦 安装
go get apigo.cc/go/task
💡 快速开始
1. 注册任务
任务函数必须遵循 func(ctx context.Context) error 签名,以便处理超时和优雅退出。
import "apigo.cc/go/task"
// 简单注册(使用默认配置)
task.Add("CleanLog", "@daily", func(ctx context.Context) error {
// 执行清理逻辑
return nil
})
// 带配置注册
task.Add("Report", "@every 1m", func(ctx context.Context) error {
// ...
return nil
}, task.Config{
Policy: task.PolicySkip, // 如果上次还没跑完,跳过本次
Timeout: 5 * time.Second, // 单次执行超时
})
2. 生命周期管理
Scheduler 实现了标准的 Service 接口,推荐通过基础设施管理。
// 启动默认调度器
task.DefaultScheduler.Start(ctx, logger)
// 手动触发任务执行
task.Run("CleanLog")
// 优雅停止:取消所有任务 Context,并等待任务返回(由 ctx 控制超时)
task.DefaultScheduler.Stop(ctx)
3. 任务控制
可以通过对象或全局方法管理任务状态。
tk := task.Get("CleanLog")
tk.Disable() // 挂起任务
tk.Enable() // 恢复任务
tk.Remove() // 彻底移除
// 查询
tasks := task.List()
🛡️ 健壮性与安全
- Panic Recovery: 框架内部自动捕获任务执行中的 Panic,并记录堆栈日志,确保调度引擎持续稳定。
- Context 传播: 任务内部应监听
ctx.Done()以响应系统的停止信号。 - 标准化日志: 集成
@go/log,自动记录每个任务的开始、成功、失败(含耗时)以及 Panic 信息。
🧪 验证状态
测试全部通过,性能达标。
详见:TEST.md