Kafka rabalance 的底层原理、触发时机以及过程

目录

[Kafka Rebalance 原理](#Kafka Rebalance 原理)

[Rebalance 触发时机](#Rebalance 触发时机)

[Rebalance 过程](#Rebalance 过程)


Kafka Rebalance 原理

  1. 消费者组和分区分配

    • Kafka 中,消费者以组的形式订阅主题,组内的消费者共同消费主题的分区。
    • Rebalance 是指重新分配消费者组内的消费者与主题分区之间的关系。
  2. 协调者(Coordinator)

    • Kafka 为每个消费者组指定了一个协调者,负责管理组内成员和分区分配。
    • 协调者根据消费者组的成员情况和分区策略来决定分区的分配。
  3. 分区分配策略

    • Kafka 提供了多种分区分配策略,如 Range、RoundRobin 和 Sticky 等。
    • 分区分配策略决定了分区如何分配给消费者。
  4. 消费者心跳

    • 消费者定期向协调者发送心跳,证明它们仍然活跃。
    • 如果协调者在特定时间内未收到心跳,它会认为消费者已经失效。
  5. 分区所有权

    • 当分区被分配给消费者后,消费者成为该分区的所有者。
    • 只有分区的所有者能够消费该分区的消息。

Rebalance 触发时机

  1. 消费者加入或离开

    • 当新的消费者加入消费者组或现有消费者离开组时,会触发 Rebalance。
    • 加入和离开可以是消费者的启动、关闭或崩溃。
  2. 主题分区数变化

    • 如果一个消费者组订阅的主题增加了分区,这也会触发 Rebalance。
  3. 协调者发现消费者失效

    • 如果消费者未在规定时间内发送心跳,协调者会认为该消费者失效,并触发 Rebalance。
  4. 协调者自身的更换

    • 如果负责消费者组的协调者发生变化,也会触发 Rebalance。
  5. 消费者组内成员变化

    • 消费者组内成员发生变化,比如消费者的订阅模式或订阅主题列表变化,也会触发 Rebalance。

Rebalance 过程

  1. 停止消息消费

    • 一旦 Rebalance 被触发,消费者将停止消费消息。
  2. 重新分配分区

    • 协调者使用分区分配策略重新分配分区给消费者组内的成员。
  3. 同步状态

    • 消费者可能需要处理一些状态同步的问题,比如提交偏移量。
  4. 恢复消息消费

    • 一旦分区重新分配完毕,消费者将开始消费新分配的分区。

Rebalance 是 Kafka 保证消费者组高可用性和扩展性的关键机制,但频繁的 Rebalance 可能会对性能产生负面影响,因此需要合理配置消费者心跳和会话超时参数,以及合理使用消费者组。

相关推荐
_F_y4 小时前
仿RabbitMQ实现消息队列-服务端核心模块实现(4)
分布式·rabbitmq
Albert Edison7 小时前
【RabbitMQ】发布确认模式(使用案例)
分布式·rabbitmq·ruby
EXnf1SbYK9 小时前
Redis分布式锁进阶第十二篇:全系列终极兜底复盘 + 锁架构巡检落地 + 线上零事故收尾方案
redis·分布式·架构
EXnf1SbYK9 小时前
Redis分布式锁进阶第八篇:锁超时乱序深度踩坑 + 看门狗失效真实溯源 + 业务长耗时标准化兜底方案
数据库·redis·分布式
EXnf1SbYK9 小时前
Redis分布式锁进阶第十一篇
数据库·redis·分布式
biyezuopinvip10 小时前
分布式风电场低电压穿越故障建模与仿真
分布式·matlab·毕业设计·毕业论文·分布式风电场·低电压穿越故障·建模与仿真
苍煜10 小时前
SpringBoot单体应用到分布式下的数据库锁、事务、Redis事务、分布式锁、分布式事务协调
数据库·spring boot·分布式
fengxin_rou10 小时前
黑马点评项目万字总结:从redis基础到实战应用详解
java·开发语言·分布式·后端·黑马点评
ErizJ11 小时前
Kafka | 学习笔记
笔记·学习·kafka
小江的记录本21 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka