Golang 如何解耦多层级 kafka consumer 比较好?

2020-07-20 20:42:26 +08:00
 Darain

简单描述一下当前的业务设计:

1.主线程从 kafka 读消息 (message)

2.把 message 根据 id 对 partition 取模转发给 dispatcher (dispatcher 数量 = partiton 大小)

3.dispatcher 转发 message 给 concurrent handler (一个 dispatcher 对应多个 concurrent handler)

4.concurrent handler 内有若干 message handler. 每个 concurrent handler 处理一类表(分表)的消息.

5.message handler 内有一个 handler.

6.handler 是实现了 Handle() 方法的实际业务处理者.(一条 message 被一个 handler 处理)

dispatcher 的设计目的是为了维护 partition offset.

concurrent message handler 的设计目的是简单的内部扩容,

message handler 的设计目的是复用业务判断和错误处理, 让 handler 可以只写业务.

目前的主要问题是, 我都是用 NewXX() 和 Run()方法, 在每一个 Run() 方法调用它的子 handler 的 Run(). 在 NewXX()方法里调用子 handler 的 NewXX() 方法.

最后导致代码结构比较复杂, 而且很难理清. 不知道该怎么优化

或者应该看些什么书 /文章比较好. 感觉思路是对的, 就是代码写的太绕了

1726 次点击
所在节点    Go 编程语言
2 条回复
madNeal
2020-07-20 21:51:18 +08:00
为啥不用现成的轮子

https://github.com/segmentio/kafka-go
superfat
2020-07-21 09:36:27 +08:00
我最近也在用这个库做 consumer 相关开发

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/691711

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX