责任链与中介者模式在Go中的应用
时间:2025-12-29 12:10:35 482浏览 收藏
“纵有疾风来,人生不言弃”,这句话送给正在学习Golang的朋友们,也希望在阅读本文《责任链与中介者模式在Go中的链式请求实现》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新Golang相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!
责任链与中介者模式协同使用:责任链负责请求逐级处理与传递,中介者解耦节点、统一协调流程与状态,支持动态注册、顺序调整、上下文共享及条件分支。

在 Go 语言中,责任链(Chain of Responsibility)和中介者(Mediator)模式可以协同使用:责任链负责请求的**逐级处理与传递**,中介者则负责**解耦各处理节点、统一协调流程与状态**。这种组合特别适合需要灵活扩展处理步骤、又要求节点间低耦合、流程可控的场景(如 API 请求预处理、工作流引擎、消息路由等)。
核心设计思路:分离“流转逻辑”与“协调逻辑”
责任链本身是线性的、静态的调用链;而中介者引入后,可动态注册/移除处理器、修改执行顺序、注入共享上下文、甚至根据运行时状态跳过或分支处理——链不再硬编码,而是由中介者驱动。
关键点:
- 每个处理器(Handler)不直接引用下一个 Handler,而是通过中介者获取后续动作
- 中介者持有所有已注册的处理器,并管理它们的执行顺序与依赖关系
- 请求对象(Request)需携带可变上下文(如 Context、Map、或自定义 Payload),供各 Handler 读写
基础结构定义:Handler 接口与 Mediator 核心
定义统一的处理器接口,接收请求并返回是否继续流转:
// Handler 处理器接口,返回 true 表示继续传递,false 表示终止type Handler interface {
Handle(req *Request) bool
}
// Request 是可扩展的请求载体,支持键值上下文
type Request struct {
Data map[string]interface{}
ctx context.Context
}
func NewRequest() *Request {
return &Request{Data: make(map[string]interface{})}
}
// Mediator 中介者,集中管理 Handler 生命周期与执行逻辑
type Mediator struct {
handlers []Handler
order map[string]int // 可选:支持按名称排序或条件跳转
}
func NewMediator() *Mediator {
return &Mediator{handlers: make([]Handler, 0), order: make(map[string]int)}
}
func (m *Mediator) Register(h Handler) {
m.handlers = append(m.handlers, h)
}
func (m *Mediator) Handle(req *Request) {
for _, h := range m.handlers {
if !h.Handle(req) {
break
}
}
}
实战示例:API 请求的链式校验 + 中心日志/熔断协调
假设一个 HTTP 请求需依次做:鉴权 → 限流 → 参数校验 → 缓存检查。其中限流和缓存需共享 Redis 客户端,熔断状态需全局感知——这些共享资源与策略不应由 Handler 自行管理,而交由 Mediator 统一注入。
实现方式:
- Mediator 初始化时注入 Redis 客户端、熔断器、Logger 等共享依赖
- 每个 Handler 通过构造函数接收 Mediator 实例(或只接收所需依赖),避免强耦合
- Handler 内部可调用 mediator.GetCache() 或 mediator.IsCircuitOpen() 等协调方法
- 中介者还可提供 Before/After 钩子,在整条链前后执行审计或指标上报
例如限流 Handler:
// RateLimitHandler 使用中介者提供的限流器type RateLimitHandler struct {
mediator *Mediator
}
func NewRateLimitHandler(m *Mediator) *RateLimitHandler {
return &RateLimitHandler{mediator: m}
}
func (h *RateLimitHandler) Handle(req *Request) bool {
if !h.mediator.RateLimiter.Allow(req.Data["client_id"].(string)) {
req.Data["error"] = "rate limited"
return false
}
return true
}
进阶能力:动态链与条件分支
中介者可支持更复杂的流程控制,比如:
- 条件跳过:根据请求类型(如 req.Data["type"]=="admin")跳过某些 Handler
- 分支执行:将请求分发到不同子链(如 /v1/* 走旧链,/v2/* 走新链)
- 异常重试链:某 Handler 失败后,由中介者触发降级 Handler 链
- 异步协作:部分 Handler 提交 goroutine 异步执行,中介者统一 WaitGroup 或监听完成信号
示例:动态选择子链
// 在 Mediator.Handle 中if version := req.Data["version"]; version == "v2" {
m.handleV2Chain(req)
} else {
m.handleV1Chain(req)
}
不复杂但容易忽略:Go 的接口组合与依赖注入天然适合这种模式。真正难点不在代码实现,而在厘清“谁该决定流程走向”——把决策权交给 Mediator,而非让 Handler 彼此通信,才是解耦的关键。
本篇关于《责任链与中介者模式在Go中的应用》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
-
234 收藏
-
264 收藏
-
144 收藏
-
216 收藏
-
156 收藏
-
300 收藏
-
224 收藏
-
265 收藏
-
354 收藏
-
412 收藏
-
378 收藏
-
333 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习