task/README.md

79 lines
2.3 KiB
Markdown
Raw Permalink Normal View History

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