Context是Go中管理并发任务的核心工具,通过context.WithCancel可实现任务取消,调用cancel函数通知所有子任务退出;使用context.WithTimeout或WithDeadline可设置超时控制,超时后Done()通道关闭,任务需监听并及时终止。

在Go语言中,Context 是管理并发任务生命周期的核心工具。它能控制多个goroutine的运行时机,实现超时、取消和传递请求范围的数据。当你启动多个并发任务并希望统一控制它们的执行周期时,Context 提供了一种简洁高效的机制。
使用 Context 实现任务取消
当你需要在某个条件满足后停止所有正在运行的任务时,可以使用 context.WithCancel 创建可取消的上下文。
示例场景:用户请求被中断,需立即停止所有相关协程。调用 cancel 函数会关闭关联的 channel,所有监听该 Context 的 goroutine 可以收到信号并退出。
- 通过 context.WithCancel(parent) 获取 ctx 和 cancel 函数
- 将 ctx 传入各个子任务
- 当调用 cancel() 时,所有基于此 ctx 的任务都会收到 Done() 通知
设置超时控制并发任务
很多情况下我们不希望任务无限等待,比如网络请求或数据库查询。这时可以用 context.WithTimeout 或 context.WithDeadline 来限制最长执行时间。
立即学习“go语言免费学习笔记(深入)”;
WithTimeout 设置相对时间,WithDeadline 设定绝对截止时间。一旦超时触发,Context 的 Done() channel 就会被关闭,正在运行的任务应监听这个信号及时退出。
- 使用 context.WithTimeout(context.Background(), 3*time.Second) 设置三秒超时
- 每个子任务定期检查
- 及时释放资源,避免 goroutine 泄漏
在任务间传递共享数据
Context 还支持携带键值对数据,适用于在请求链路中传递元信息,如用户身份、trace ID 等。
注意:仅用于传递请求级数据,不要用来传递可选参数。使用 context.WithValue 向 Context 添加数据,在下游任务中通过 ctx.Value(key) 获取。
- 创建 valueCtx:ctx := context.WithValue(parent, "userID", 1234)
- 在处理函数中安全取值:val := ctx.Value("userID")
- 建议 key 使用自定义类型避免冲突
结合 errgroup 简化并发控制
对于需要等待多个任务完成且能自动传播取消信号的场景,errgroup.Group 是更高级的选择。
它封装了 Context 管理和错误收集,适合构建可靠的服务处理流程。
- 导入 golang.org/x/sync/errgroup
- 每个任务由 Go 方法启动,自动继承同一个 Context
- 任一任务返回非 nil 错误,其他任务将被取消
基本上就这些。合理使用 Context 能让你的并发程序更可控、更健壮。关键是把 ctx 当作参数传递给所有阻塞操作,并始终监听它的结束信号。不复杂但容易忽略。










