Kafka消费者原理解析

消费者和消费组

生产者和消费者往往是一对多的关系,多个消费者可以形成一个消费组来订阅主题消息,对消息进行分类。一个消费组中订阅的都是同一个主题,每个消费者接受主题一部分分区的消息。同一个消费组内的不同消费者只能订阅一个主题下不同分区的消息,不同消费组可以订阅同一个主题的统一分区消息

在同一个消费组下,根据消费者数量的不同,消费者订阅的主题数量也会变化,假设一个主题有4个分区p1,p2,p3,p4,只有唯一的消费者c1,则订阅关系为:

c1->p1
c1->p2
c1->p3
c1->p4

如果有两个消费者c1,c2,则订阅关系会发生变化,可能会变成:

c1->p1
c2->p2
c1->p3
c2->p4

如果消费者数量大于分区数,则会导致部分消费者闲置,不会接收到任何消息。如有5个消费者:

c1->p1
c2->p2
c3->p3
c4->p4
c5 闲置

从上面分析,可以通过适当地增加消费者数量来横向拓展消费能力,这是尤其当消费者需要做一些高延迟处理或发送者发送速率较大的情况下。但不要让消费者数量超过主题分区数。

一个消费组即可保证生产者生产的所有消息都被唯一消费,但如果存在多方对生产的消息感兴趣,可以初始化不同的消费组,不同消费组互不干扰,都分别能对生产者生产的所有消息进行唯一消费。示例如下所示:
image

对于消费组,有5个状态:

  1. Empty:消费组下没有任何活跃的消费者,可能为消费组刚创建的时刻或工作一段时间后所有消费者离开。
  2. PreparingRebalance:表明group正在准备进行group rebalance。此时group收到部分成员发送的JoinGroup请求,同时等待其他成员发送JoinGroup请求,知道所耦成员都成功加入组或超时。
  3. AwaitingSyc:表明所有成员都已经加入组并等待leader consumer发送分区分配方案。
  4. Stable:表明group开始正常消费,可以响应客户端发送的任何请求
  5. Dead:表明group已经彻底废弃,group内没有任何active成员且group的所有元数据都已被删除。

对应以下生命周期流转模型:
image

创建Kafka消费者

类似生产者,在创建消费者时,同样需要指定三个最基本的属性:

  1. boostrap.servers:指定kafka集群的连接地址
  2. key.deserializer: 消息中key的反序列化工具类
  3. value.deserializer:消息中value的反序列化工具类

在3个必备配置外,还有一个最基本配置group.id,用来指定消费者属于哪一个消费者群组,如果不指定会分配在默认消费组,但这不太常见。

下面来看一个创建示例:

Properties properties = new Properties();
// 指定broker连接
properties.setProperty("bootstrap.servers", "127.0.0.1:9092");
// 指定key反序列化工具类
properties.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
// 指定value反序列化工具类
properties.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
// 指定消费群组id
properties.setProperty("group.id", "test2");
// 初始化消费者
KafkaConsumer<String, String> consumer = new KafkaConsumer<>(properties);
// 指定订阅主题,可以同时订阅多个主题,还可以通过指定test*订阅所有test开头的主题
consumer.subscribe(Collections.singletonList("kafka-topic"));

// 循环消费消息
while (true) {
   
    // 不断尝试拉取
    ConsumerRecords<String, String> records = consumer.
  • 1
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值