栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

kafka位移提交问题

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

kafka位移提交问题

自动提交
(系统默认值为5秒,缩短位移提交间隔,可以更好防止数据丢失和重复消费问题)
// 自动提交,默认true

props.put("enable.auto.commit", "true");
// 设置自动每1s提交一次
props.put("auto.commit.interval.ms", "1000");

自动提交是在轮询中进行,消费者每次轮询时都会检查是否提交该偏移量。这种情况就会发生重复消费和丢失消息的情况。
手动提交(consumer.commitSync())

// 关闭自动提交
props.put("enable.auto.commit", false);
// 业务处理结束执行
try {
    // 这里进行提交
    // 用commitSync()提交由poll方法返回的最新偏移量,如果提交成功马上返回,提交失败则抛出异常。
    consumer.commitSync();
} catch (CommitFailedException e) {
    System.out.println(e.getMessage());
}

在于提交请求后,broker响应之前应用程序会一直阻塞,这样就会限制应用程序的吞吐量。
一旦发生再均衡,会增加重复消息的数量
异步提交(consumer.commitAsync(callback))

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/696988.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号