kafka rebalance机制

来源:互联网 发布:2016世界各国经济数据 编辑:程序博客网 时间:2024/06/05 15:59

     Kafka保证同一consumer group中只有一个consumer会消费某条消息,实际上,Kafka保证的是稳定状态下每一个consumer实例只会消费某一个或多个特定的数据,而某个partition的数据只会被某一个特定的consumer实例所消费。这样设计的劣势是无法让同一个consumer group里的consumer均匀消费数据,优势是每个consumer不用都跟大量的broker通信,减少通信开销,同时也降低了分配难度,实现也更简单。另外,因为同一个partition里的数据是有序的,这种设计可以保证每个partition里的数据也是有序被消费。

  如果某consumer group中consumer数量少于partition数量,则至少有一个consumer会消费多个partition的数据,如果consumer的数量与partition数量相同,则正好一个consumer消费一个partition的数据,而如果consumer的数量多于partition的数量时,会有部分consumer无法消费该topic下任何一条消息。

Consumer Rebalance算法如下 :  

  1. 1. 将目标 topic 下的所有 partirtion 排序,存于PT
  2. 2. 对某 consumer group 下所有 consumer 排序,存于 CG,第 i consumer 记为 Ci
  3. 3. N=size(PT)/size(CG),向上取整
  4. 4. 解除 Ci 对原来分配的 partition 的消费权(i0开始)
  5. 5. 将第i*N到(i+1)*N-1 partition 分配给 Ci  

目前consumer rebalance的控制策略是由每一个consumer通过Zookeeper完成的。具体的控制方式如下:

  1. 在/consumers/[consumer-group]/下注册id
  2. 设置对/consumers/[consumer-group] watcher
  3. 设置对/brokers/idswatcher
  4. zk下设置watcher的路径节点更改,触发consumer rebalance

    在这种策略下,每一个consumer或者broker的增加或者减少都会触发consumer rebalance。因为每个consumer只负责调整自己所消费的partition,为了保证整个consumer group的一致性,所以当一个consumer触发了rebalance时,该consumer group内的其它所有consumer也应该同时触发rebalance。
  • Herd effect
  任何broker或者consumer的增减都会触发所有的consumer的rebalance
  • Split Brain
  每个consumer分别单独通过Zookeeper判断哪些partition down了,那么不同consumer从Zookeeper“看”到的view就可能不一样,这就会造成错误的reblance尝试。而且有可能所有的consumer都认为rebalance已经完成了,但实际上可能并非如此。


0 0
原创粉丝点击