.net Kafka.Client多个Consumer Group对Topic消费不能完全覆盖研究总结

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了.net Kafka.Client多个Consumer Group对Topic消费不能完全覆盖研究总结相关的知识,希望对你有一定的参考价值。

依据Partition和Consumer的Rebalance策略,找到Kafka.Client Rebalance代码块,还原本地环境,跟踪调试,发现自定义Consumer Group 的Consumer并没有分配到PartionID,如下图、

技术分享

技术分享

据此,基本就可以定位到不同组Consumer无法覆盖Partition的问题根源了。

仔细阅读Rebalance代码,发现Kafka.Client 在获取consumer时,并没有根据Group做筛选,获取到的是所有组的Consumer,如下图

(此处只有两个不同组的Consumer类型,每个Consumer会生成五个ConsumerThreadID,用于覆盖partition)

技术分享

技术分享

定位curConsumer变量,从consumerPerTopicMap中获取,找到consumerPerTopicMap的实现

技术分享

此处确实没有过滤

技术分享

技术分享

增加group过滤代码。问题解决。

技术分享

技术分享

以上是关于.net Kafka.Client多个Consumer Group对Topic消费不能完全覆盖研究总结的主要内容,如果未能解决你的问题,请参考以下文章

解决.NET WebService引用后添加HTTP Header的问题

Kafka:使用普通消费者组访问多个主题

kafka consumer重新连接后如何获取当前最新数据

转载:SQL按照日周月年统计数据的方法

启动kafka报错

方法引用