Kafka 消息不丢失
创始人
2024-06-01 01:22:09
0

Kafka 消息不丢失

  • 生产者丢失
  • 消费者丢失
  • 不丢失配置

Kafka 保证消息不丢失:只对已提交的消息 (committed message) 做有限度的持久化保证

  • 已提交的消息:当 n 个 Broker 成功接收到该消息并写入到日志文件后,就告诉生产者该消息已成功提交
  • 有限度的持久化保证 : 消息保存在 N 个 Broker 上,要至少有 1 个存活
  • Kafka 只对已提交的消息,并满足一定的条件,能实现不丢失消息

生产者丢失

Kafka Producer 是异步发送消息的 ,调用 producer.send(msg),会立即返回,就无法知道消息是否发送成功

消息发送不成功的原因:

  • 网络抖动 : 导致消息就没有发到 Broker 端
  • 消息本身不合格,导致 Broker 拒绝接收 (如 : 消息太大)
  • 所有的 Broker 都挂了

解决方法:Producer 用 producer.send(msg, callback)有回调通知的发送 API

消费者丢失

Consumer 端的位移:

  • 位移:该 Consumer 消费当前 Topic 分区的位置

Consumer 的对位移的消息丢失解决:

  • 先消费消息,再更新位移的顺序
  • 能最大限度地保证消息不丢失,但可能消息的重复处理

在这里插入图片描述

Consumer 用多个线程异步处理消息,并自动更新位移

  • 当某个线程运行失败,某个消息没有被成功处理,但位移已经更新,该消息对 Consumer 就是丢失状态
  • 解决方案:Consumer 手动提交位移

不丢失配置

  • 当 ISR 只有 1 个副本 ,acks=all ,相当于 acks=1
  • min.insync.replicas 目的 :下限的限制
  • 不能只满足 ISR 全部写入,还要保证 ISR 中的写入个数大于 min.insync.replicas
  • 对可重试的错误,retries 才会触发,否则直接进入到 callback
Producerproducer.send(msg, callback)用带回调通知的 send 方法
acks = allall:所有副本 Broker 都接收到消息,才认为已提交
retries > 0自动重试消息发送,避免消息丢失
Brokerunclean.leader.election.enable = false不允许落后 Leader的Broker,成为新Leader
replication.factor >= 3消息多副本
min.insync.replicas > 1消息至少要写入 n 个副本才是已提交
replication.factor = min.insync.replicas + 1防止一个副本挂了,整个分区就无法正常工作
Consumerenable.auto.commit = false手动提交位移

相关内容

热门资讯

长源东谷跌3.17%,成交额9... 7月2日,长源东谷跌3.17%,成交额9349.01万元,换手率1.19%,总市值78.15亿元。异...
宇环数控跌0.87%,成交额5... 7月2日,宇环数控跌0.87%,成交额5008.02万元,换手率2.49%,总市值30.21亿元。异...
天箭科技跌4.64%,成交额2... 7月2日,天箭科技跌4.64%,成交额2.99亿元,换手率11.06%,总市值48.41亿元。异动分...
新经典跌1.22%,成交额46... 7月2日,新经典跌1.22%,成交额4675.15万元,换手率1.62%,总市值28.75亿元。异动...
彤程新材跌0.92%,成交额2... 7月2日,彤程新材跌0.92%,成交额2.55亿元,换手率1.32%,总市值193.40亿元。异动分...
百傲化学跌4.87%,成交额3... 7月2日,百傲化学跌4.87%,成交额3.29亿元,换手率2.11%,总市值152.97亿元。异动分...
联瑞新材跌3.06%,成交额1... 7月2日,联瑞新材跌3.06%,成交额1.33亿元,换手率1.22%,总市值107.94亿元。异动分...
君实生物跌0.78%,成交额4... 7月2日,君实生物跌0.78%,成交额4.62亿元,换手率1.68%,总市值363.45亿元。异动分...
广州酒家跌0.38%,成交额2... 7月2日,广州酒家跌0.38%,成交额2711.53万元,换手率0.31%,总市值88.73亿元。异...
华盛昌跌0.25%,成交额79... 7月2日,华盛昌跌0.25%,成交额7941.73万元,换手率3.97%,总市值37.88亿元。异动...