spring kafka Consumer再均衡处理

spring kafka Consumer再均衡处理

Consumer再均衡场景

我们在使用kafka时难免会出现对kafka分区的调整或者消费组的增减(当然如果能尽量避免这类场景更好),在以上场景下会使kafka consumer出现在均衡情况,这样会造成消息丢失或者消息重复,下面说明下如何处理这种情况,直接上代码!

代码如下

    /**
     * @Name : 消费者再均衡处理
     * @Description : 新增消费者或移除消费者后需要从新更新消费者分区
     */
    public class SaveOffsetsOnRebalance implements ConsumerRebalanceListener {
        private KafkaConsumer consumer;

        @Override
        public void onPartitionsRevoked(Collection<org.apache.kafka.common.TopicPartition> collection) {
            // 虚构方法 --- 将记录和偏移量保存到数据库
            commitDBTransaction();
        }

        @Override
        public void onPartitionsAssigned(Collection<org.apache.kafka.common.TopicPartition> collection) {

            for(org.apache.kafka.common.TopicPartition partition : collection){
                // 从数据库中读取偏移量seek到consumer中
                consumer.seek(partition,getOffsetFormDB(partition));
                System.out.println("再均衡监听,从指定偏移量处开始消费,当前topic:{},分区:{},消费开始位置:{}" + partition.topic() + partition.partition() + "0");
            }
        }
    }

通过上面代码可以看出我们实现了ConsumerRebalanceListener消费组均衡监听类;在这个类里面有两个重写方法onPartitionsRevoked() 和 onPartitionsAssigned() ;
public void onPartitionsRevoked(Collection<org.apache.kafka.common.TopicPartition> collection) 方法在再均衡开始之前和消费组停止读取消息之后被调用。
public void onPartitionsAssigned(Collection<org.apache.kafka.common.TopicPartition> collection) 方法在重新分配分区之后和消费者开始读取消息之前被调用。

这里在消费组停止前将记录和偏移量存到db中,然后在分配分区之后调用seek() 方法将存入库中的偏移量设置进去!这样可以防止消费者发生在均衡时造成的消息丢失或者消息重复!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值