当前位置: 首页 > news >正文

Kafka 消息不丢失

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手动提交位移
http://www.lryc.cn/news/37272.html

相关文章:

  • ASEMI高压MOS管10N65参数,10N65规格,10N65封装
  • LeetCode-416. 分割等和子集
  • 2021年 第12届 蓝桥杯 Java B组 省赛真题详解及小结【第2场省赛 2021.05.09】
  • elasticSearch写入原理
  • 第十四届蓝桥杯模拟赛(第三期)Python
  • Pytorch模型参数的保存和加载
  • 面试热点题:回溯算法之组合 组合与组合总和 III
  • java面试-jvm
  • vscode下载与使用
  • 人员摔倒识别预警算法 opencv
  • 华为OD机试题 - 火星文计算(JavaScript)| 机考必刷
  • AI人工智能 - 初探
  • Spring-AOP工作流程
  • C51---串口发送指令,控制LED灯亮灭
  • 【Wiki】XWiki数据备份
  • ctk框架开发Qt插件应用示例工程
  • spring5源码篇(4)——beanFactoryPostProcessor执行/注解bean的装配
  • masstransit的message几个高级用法
  • 漏洞分析丨cve-2012-0003
  • rm命令——删除文件或目录
  • 【零基础入门学习Python---Python的基本语法使用】
  • 数据仓库相关概念的解释
  • 1/4车、1/2车、整车悬架模糊PID控制仿真合集
  • Linux性能补丁升级,避免不必要的跨核Wake-Up
  • Spring Cloud Alibaba全家桶(六)——微服务组件Sentinel介绍与使用
  • 拼多多2021笔试真题集 -- 3. 多多的求和计算
  • DP算法:动态规划算法
  • 一三四——一六七
  • day29_JS
  • 【HTTP协议与Web服务器】