storm 一直报错:Got fetch request with offset out of range

  1. jstorm一直刷如下错误消息:
    15:43:07.952 [kafka:5-SingleThreadSpoutExecutors] WARN  storm.kafka.KafkaUtils - Got fetch request with offset out of range: [22]; retrying with default start offset time from configuration. configured start offset time: [-2]
    15:43:07.955 [kafka:5-SingleThreadSpoutExecutors] WARN  storm.kafka.PartitionManager - Using new offset: 23
    
  2. 原因如下:
    1. kafka有定时清空数据,或者消息丢失。
    2. jstorm的代码里面有fail的逻辑,消息正好failed。
    3. faild的消息正好被kafka清空或者丢失了。
      如果上面条件都满足,则会一直循环包如上的错误消息。
  3. storm-kakfa对应代码如下:
    // Are there failed tuples? If so, fetch those first.
    if (had_failed) {
        offset = failed.first();
    } else {
        offset = _emittedToOffset;
    }
    ByteBufferMessageSet msgs = null;
    try {
        msgs = KafkaUtils.fetchMessages(_spoutConfig, _consumer, _partition, offset);
    } catch (UpdateOffsetException e) {
        _emittedToOffset = KafkaUtils.getOffset(_consumer, _spoutConfig.topic, _partition.partition, _spoutConfig);
        LOG.warn("Using new offset: {}", _emittedToOffset);
        // fetch failed, so don't update the metrics
        return;
    }
    

因为在jstorm bolt中有失败的消息,所以had_failed=true,所以一直从failed列表里消费第一条数据,而failed列表里的第一条数据又被kafka清空了,导致一直抛出UpdateOffsetException,然后返回又重新循环一遍,所以就会一直出现一开始的错误。

转载于:https://my.oschina.net/cjun/blog/3070465

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值