消费者重新平衡决定哪个消费者负责某些主题的所有可用分区的哪个子集。 例如,您可能有一个包含20个分区和10个使用者的主题。 在重新平衡结束时,您可能希望每个使用者都从2个分区中读取数据。 如果关闭了这些使用者中的10个,则可能会期望每个使用者在重新平衡完成后具有1个分区。 消费者重新平衡是可以由Kafka自动处理的动态分区分配。

组协调员是负责与消费者进行通信以实现消费者之间平衡的经纪人之一。在早期版本中,Zookeeper存储了元数据详细信息,但最新版本存储在经纪人上。消费者协调员收到了所有消费者组消费者的心跳和轮询,因此他了解每个消费者心跳和经理在分区上的偏移量。

小组组长:消费者组的一位消费者担任小组组长,由小组协调员选出,负责代表小组中的所有消费者做出分区分配决定。

重新平衡方案:

  1. 消费者组订阅任何主题
  2. 消费者实例无法使用session.heart.beat时间间隔发送心跳。
  3. 消费者的长时间流程超出了轮询超时
  4. 消费群体中的消费者通过例外
  5. 添加了新分区。
  6. 扩大消费者规模。 添加了新使用者或手动删除了现有使用者

消费者再平衡

消费者重新平衡是在消费者请求加入一个小组或离开一个小组时启动的。 小组负责人从小组协调员那里收到所有活跃消费者的名单。 组负责人使用PartitionAssigner决定分配给每个使用者的分区。 一旦组长完成分区分配,它就会将分配列表发送给组协调器,组协调器将这些信息发送回所有使用者。 组仅将适用的分区发送给其使用者,而不发送其他使用者分配的分区。 只有组长知道所有使用者及其分配的分区。 重新平衡完成后,消费者开始将“心跳”发送到仍活跃的“组协调器”。 使用者向组协调器发送OffsetFetch请求,以获取为其分配的分区的最后提交的偏移量。 消费者开始消费新分配分区的消息。

国家管理

重新平衡时,组协调器将其状态设置为“重新平衡”,并等待所有消费者重新加入组。

当组开始重新平衡时,组协调器首先将其状态切换为重新平衡,以便通知所有交互的使用者重新加入组。 重新平衡完成后,组协调器会创建新的ID,并通知所有消费者,然后该组继续进行同步阶段,在此阶段,消费者发送同步请求,并等待直到组长完成生成新的分配分区。一旦消费者收到新的分配分区,他们便进入稳定阶段。


静态会员

您的重新平衡操作相当繁琐,因为它需要停止所有使用者并等待获取新分配的分区。 在每次重新平衡时,始终创建新一代id,这意味着刷新所有内容。 为了解决此开销,Kafka 2.3+引入了静态成员资格以减少不必要的重新平衡。 KIP-345

在静态成员资格状态下,消费者状态将保持不变,在重新平衡状态下,将应用相同的分配。 它使用新的group.instance.id来保留成员身份。 因此,即使在最坏的情况下,成员ID也会被改组以分配新分区,但相同的使用者实例ID仍将获得相同的分区分配

 instanceId: A, memberId: 1, assignment: {0, 1, 2}  instanceId: B, memberId: 2, assignment: {3, 4, 5}  instanceId: C, memberId: 3, assignment: {6, 7, 8} 

重启后:

 instanceId: A, memberId: 4, assignment: {0, 1, 2}  instanceId: B, memberId: 2, assignment: {3, 4, 5}  instanceId: C, memberId: 3, assignment: {6, 7, 8} 

参考:

  1. https://www.confluent.io/blog/kafka-rebalance-protocol-static-membership
  2. https://cwiki.apache.org/confluence/display/KAFKA/KIP-345%3A+Introduce+static+membership+protocol+to+reduce+consumer+rebalances

翻译自: https://www.javacodegeeks.com/2020/06/apache-kafka-consumer-rebalance.html

Apache Kafka消费者再平衡相关推荐

  1. apache kafka_Apache Kafka消费者再平衡

    apache kafka 消费者重新平衡决定哪个消费者负责某个主题的所有可用分区的哪个子集. 例如,您可能有一个包含20个分区和10个使用者的主题. 在重新平衡结束时,您可能希望每个使用者都从2个分区 ...

  2. Apache Kafka Consumer 消费者集

    1.目标 在我们的上一篇文章中,我们讨论了Kafka Producer.今天,我们将讨论Kafka Consumer.首先,我们将看到什么是Kafka Consumer和Kafka Consumer的 ...

  3. Kafka系列 - 14 Kafka消费者|分区的分配策略及再平衡|Range|RoundRobin|Sticky|CooperativeSticky

    文章目录 1. 分区的分配以及再平衡 2. Range 分区分配以及再平衡 3. RoundRobin 分区分配以及再平衡 4. Sticky 分区分配以及再平衡 1. 分区的分配以及再平衡 一个co ...

  4. AKHQ:用于Apache Kafka管理主题、主题数据、消费者组、模式注册表、连接等的Kafka GUI。。。

    参考文章:https://www.5axxw.com/wiki/content/q7nyiu AKHQ(以前称为KafkaHQ) 用于Apache Kafka管理主题.主题数据.消费者组.模式注册表. ...

  5. Apache Kafka教程A系列:消费者群体示例

    原文地址:https://www.tutorialspoint.com/apache_kafka/apache_kafka_consumer_group_example.htm 消费者群体(group ...

  6. kafka消费者分区的分配的三种机制

    1.RangeAssignor RangeAssignor策略的原理是按照消费者总数和分区总数进行整除运算来获得一个跨度,然后将分区按照跨度进行平均分配,以保证分区尽可能均匀地分配给所有的消费者.对于 ...

  7. 深入浅出系列之 -- kafka消费者的三种语义模型

    本文主要详解kafka client的使用,包括kafka消费者的三种消费语义at-most-once,at-least-once,和exact-once message,生产者的使用等. 创建主题 ...

  8. 每个 Apache Kafka 开发者都应该知道的5件事

    Apache Kafka 是一个开源流处理平台,如今有超过30%的财富500强企业使用该平台.Kafka 有很多特性使其成为事件流平台(event streaming platform)的事实上的标准 ...

  9. kafka基础入门(4):kafka消费者

    kafka消费者 kafka消费方式 kafka采用pull(拉)模式,consumer从broker中拉取数据 pull模式的不足:如果Kafka没有数据,消费者可能会陷入循环中,一直返回空数据 k ...

最新文章

  1. Linux启动过程分析
  2. 面向对象的软件测试技术
  3. 学科实践活动感悟50字_中学生学科实践活动50字
  4. 2003服务器系统密码忘记,服务器系统2003 设置密码
  5. Java针对ArrayList自定义排序的2种实现方法
  6. mysql的seq2_DESeq2处理TCGA数据库Seq-count数据
  7. 深入理解CSS六种颜色模式
  8. Airflow 中文文档:保护连接
  9. 有做行业站的转行做企业站的吗?
  10. fragment中嵌套viewpager,vierpager中用fragment不显示数据
  11. 捷达vs7测试_没有大众车标的光环,捷达VS7显得更厚道,看看是不是你的菜
  12. Centos7.0下MySQL的安装
  13. 【2019牛客暑期多校训练营(第八场)E】Explorer【线段树分治维护图连通】
  14. FFMPEG模拟直播源
  15. 开关电源PFC电路原理详解及matlab仿真
  16. 暴雪正在等待另一项_战网正在等待另一项安装或更新_魔兽世界 升6.0 战网更新一直卡在正在等待另一项安装或更新 已尝试离线 还是各种等待 求大神破...
  17. 中国象棋中的跳马问题(BFS)
  18. 国家网信办《网络数据安全管理条例(征求意见稿)》为企业带来哪些新思考?
  19. 华为3Com孤单上路
  20. java画五角星_java 画五角星 填充五角星

热门文章

  1. P2766-最长不下降子序列问题【网络流,dp】
  2. Ch4302-IntervalGCD【线段树,树状数组,GCD】
  3. ZOJ1654-Place the Robots【最大匹配,图论】
  4. 2021牛客暑期多校训练营7 B-xay loves monotonicity(线段树+不降子序列)
  5. 有上下界网络流问题汇总
  6. 动态规划训练15 [Monkey and Banana HDU - 1069 ]
  7. XML解析(一),SAX解析XML
  8. 非常有用的并发控制-倒计时器CountDownLatc
  9. C#的protected internal
  10. SpringCloudBus(了解)