Kafka数据丢失原因及解决方案_kafka消息丢失解决方案(1)

解决方法:修改ack设置为-1。(可以结合幂等性做到Exactly Once)

Broker端

丢失原因:数据从Producer端push过来后,Broker端需要将数据持久化存储到磁盘中,消息存储是异步存储的,即按照一定的消息数量和间隔时间进行存储,数据会先放在 PageCache 中,如果在存储的时候Broker宕机,此时选举了一个落后Leader Partition 很多的 Follower Partition 成为新的Lerder Partition,那么落后的消息就会丢失。

解决方法:修改参数,设置有资格成为Leader的Follower(落后太久的不要),设置分区数≥3(Leader宕机后可以有Follower补上),设置消息至少要被写入成功到ISR多少个副本才算“已提交”。

Consumer端

丢失原因:Consumer拉取消息后最终处理完需要提交 Offset,提交Offset有以下三种方式:

  1. 自动提交Offset。
  2. 拉取消息后,先提交offset、再处理消息,如果此时处理消息的时候宕机,由于Offset已提交,Consumer重启后会从之前已提交的offset 下一个位置开始消费,之前未处理的消息不会被再次处理,对于Consumer来说消息已经丢失。
  3. 拉取消息后,先处理消息、再提交Offset,如果此时在提交之前宕机,由于Offset没有提交,Consumer重启后会从上次的Offset重新拉取消息,不会丢失数据,但会出现重复消费的情况,这里只能业务自己保证幂等性。

方式2会导致数据丢失。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数大数据工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
img

[外链图片转存中…(img-Ou6C1snO-1712526595761)]

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你好!关于Kafka数据丢失问题,我可以为你提供一些建议。首先,要确定数据是否真的丢失了,可以通过以下方式进行排查: 1. 检查Kafka集群的健康状态:确保Kafka集群正常运行,没有任何错误或警告信息。 2. 检查生产者配置:确认生产者的acks参数设置正确。该参数决定了生产者在接收到消息后的确认行为。如果该参数设置为0,可能会导致数据丢失。建议将其设置为1或all。 3. 检查消费者配置:确保消费者的auto.offset.reset参数设置为earliest,这样可以从最早的可用偏移量开始消费消息。 4. 检查磁盘空间:如果磁盘空间不足,可能会导致消息丢失。请确保Kafka服务器的磁盘有足够的可用空间。 如果确认数据确实丢失了,可以尝试以下解决方案: 1. 检查日志文件:查看Kafka服务器的日志文件,查找任何与数据丢失相关的错误或警告信息。 2. 检查网络连接:确保网络连接稳定,并且没有任何网络故障或丢包情况。 3. 配置备份和复制:使用Kafka的备份和复制机制来提高数据的可靠性。通过设置副本因子来确保消息被复制到多个Broker上。 4. 监控和告警:配置监控和告警系统,及时发现并处理数据丢失问题。可以使用Kafka的监控工具或第三方监控工具。 这些是一些常见的排查和解决方法,希望对你有所帮助!如果你有更具体的问题,欢迎继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值