kafka offset 机制

kafka消息处理类:MessageAndOffset

case class MessageAndOffset(message: Message, offset: Long) {
    /**
   * Compute the offset of the next message in the log
   */
  def nextOffset: Long = offset + 1
}

其主构造方法的参数offset:是这条message上一条的offset  =》 lastOffset = messageAndOffset.offset(); 

其主构造方法的参数message:是需要处理的消息,其offset=lastOffset+1     =    messageAndOffset.nextOffset()

lastOffset (即MessageAndOffset.offset)是已经消费过的offset数据(可能是无效message的offset)

kafka  consumer 消费数据是通过lastOffset来处理消息message (message.offset=lastOffset+1)

通过lastOffset来判断是否有未处理的数据,若有消息pull下来,封装在MessageAndOffset(message,lastOffset)中

kafka offset是从1开始计数,0是没有数据

 

创建topic时,创建partition文件,topic没有数据,定义其lastOffset=0,文件名是0

partition的文件名称是以存入数据的第一条message的lastOffset做为文件名

//从zookeeper中获取,获得的是订阅者消费过的offset(即是当前message的lastOffset);
//message对应的真实offset是(lastOffset+1)
Long offset = kafkaOffset.getOffset(leadBroker, i);
//获得是最旧有效message的lastOffset;可能是通过文件名成来获取的(待源码校验)
Long et=      kafkaOffset.getEarliestOffset(consumer,i);
//topic的最新offset,是有效值。
Long ft=      kafkaOffset.getLatestOffset(consumer,i);

代码实现:

for (MessageAndOffset messageAndOffset : fetchResponse.messageSet(topic, partition)) {
    long lastOffset = messageAndOffset.offset();
    if (lastOffset < readOffset) {
        log.warn("Topic:" + topic + " and Partition:" + partition + "Found an  old offset: " + lastOffset + " Expecting: " + readOffset);
        continue;
    }
    //lastOffset是上次已经消费过的message.offset
    //每个message的真实offset=(lastOffset+1)
     readOffset = messageAndOffset.nextOffset();
    ByteBuffer payload = messageAndOffset.message().payload();

    byte[] bytes = new byte[payload.limit()];
    payload.get(bytes);

    JSONObject value = JSONObject.parseObject(new String(bytes, "utf-8"));
    list.add(value);
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值