消费者组这一章节中提到过重平衡Rebalance,Rebalance 就是让 Consumer Group 下所有的 Consumer 实例就如何消费订阅主题的所有分区达成共识的过程。在 Rebalance 整个过程中,所有实例都不能消费任何消息,因此它对 Consumer 的 TPS 影响很大。
在整个重平衡过程中,是在协调者 Coordinator 得参与下完成的,它专门为 Consumer Group 服务,负责执行 Rebalance 以及提供位移管理和组成员管理等。
Consumer 端应用程序在提交位移时,其实是向 Coordinator 所在的 Broker 提交位移。同样地,当 Consumer 应用启动时,也是向 Coordinator 所在的 Broker 发送各种请求,然后由 Coordinator 负责执行消费者组的注册、成员管理记录等元数据管理操作。
所有 Broker 在启动时,都会创建和开启相应的 Coordinator 组件。Consumer Group 如何确定为它服务的 Coordinator 在哪台 Broker 上呢?其实就是通过我们上一节提到的内部位移主题 __consumer_offsets。
确定 Coordinator 所在的 Broker 有 2 个步骤:
实际使用过程中,Consumer 能够自动发现并连接正确的 Coordinator。这个算法能够帮助我快速定位问题。当 Consumer Group 出现问题,需要快速排查 Broker 端日志时,我们能够根据这个算法准确定位 Coordinator 对应的 Broker,不必一台一台查。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。