MQ如何保证消息不丢失

news2025/1/15 12:47:03

如何保证消息不丢失

哪些环节会造成消息丢失

其实主要就是跨网络的环境中需要考虑消息的丢失,主要是有以下几个方面

  • 生产者往MQ发送消息
  • MQ的Broker是集群有主从的,主节点把消息同步到从节点时也需要考虑消息丢失问题
  • 消息从内存持久化到硬盘时,MQ的消息是工作在内存中的,但是内存是断电就丢失数据,所以需要持久化到磁盘,这一步也需要考虑消息丢失问题
  • 消费者消费MQ的消息

如下图所示的四个步骤都有可能造成消息丢失

在这里插入图片描述

如何去防止消息丢失

其实也就是针对上面四个环节来分析,保证每个环节的消息不丢失

  • 生产者发送消息不丢失

    • kafka:消息发送+回调。生产者向MQ发送一个消息之后,MQ会向生产者发送一个请求执行相应的回调函数,如果一直没有执行回调函数Produce就知道消息发送失败了就可以重新发送消息

    • RocketMQ:它是Kafka之后出来的,也支持消息发送+回调的机制。同时它还支持事务消息来保证生产者发送消息不丢失

      RocketMQ的事务消息是保证生产者 本地事务和发送消息两步是原子性的:

      1. Producer向MQ发送一个half消息(对于Consumer是不可见的),首先确定MQ是正常运行的

      2. 执行本地事务

      3. 向MQ发送真正的消息,并携带本地事务的执行结果

      4. 如果本地事务执行结果是成功,那么消费者就可以消费此消息;如果本地事务执行结果是失败,那么MQ就会丢弃此消息;如果本地事务执行结果是未知,那么就会经过以下的步骤

      5. 过一段时间MQ向Producer发送一个请求回查本地事务的执行结果

      6. Producer会执行相应的操作去检查当前 本地事务的执行结果,并将结果发送给MQ

      7. MQ再判断本地事务的执行结果,如果还是未知就继续重复执行5~7步,默认会重复执行15次。

        在这里插入图片描述

    • RabbitMQ:

      也支持消息发送+回调的机制。

      它还支持手动事务机制。

      RabbitMQ的提供了这些API方法,让我们程序自己去实现事务的逻辑

      channel.txSelect()开启事务 channel.txCommit()提交事务 channel.txRollback()回滚事务

      我们首先开启事务,然后执行本地事务,再执行后面两个Api方法。这种手动事务机制有一个问题就是对channel是会产生阻塞的,会造成吞吐量下降

      在RabbitMQ3.*版本开始,它还支持Publisher Confirm机制,相当于是生产者确认机制,整个处理流程和RocketMQ事务消息的处理流程基本是一样的

  • MQ主从同步消息不丢失

    • RocketMQ

      在RocketMQ中对于普通集群,主从数据复制有两种方式:同步复制和异步复制。同步复制就能保证消息不丢失,异步复制效率高但是可能丢消息

      第二种方式就是Dledger集群,它在主从数据复制时采用两阶段提交来保证消息不丢失

      ​ 普通集群就是我们指定哪个节点是Master,哪个节点是Slave;而Dledger集群会频繁的隔一段时间从至少三个节点中选举一个节点成为Master,其余的为Slave,当Producer发送消息到Master后,Master会直接返回给Producer,然后当前消息会标记为UnCommited,再给Slave进行消息同步,当大部分Slave都同步成功后才会把消息的状态改为Commited。这就是这里的两阶段。

    • RabbitMQ

      普通集群:消息是分散存储在各个节点,节点之间不会主动进行消息同步,只有在消费时才会进行消息同步。就比如Producer生产一个消费发送到了A节点,这个时间集群中各个节点是不同步消息的,Consumer却在B节点上消费这条消息,这个时候才会把A节点的消息同步到B节点来 再进行消费。这种方式是可以丢失消息的

      镜像集群:当Producer生产一个消息后,各个节点之间会主动的进行消息的同步,这样数据安全性会更高

    • Kafka

      它通常是在允许少量消息丢失的场景,它可以通过配置acks,配置为0 1 all 。这就相当于RocketMQ的同步复制/异步复制

  • MQ消息持久化存盘时消息不丢失

    • RocketMQ:提供了一种配置的方式,可以选择同步刷盘,也可以选择异步刷盘
    • RabbitMQ:将队列配置成持久化队列,这样就可以保证消息不丢失。在RabbitMQ3.*版本中还有一个Quorum类型的队列,会采用Raft协议来进行消息同步
  • 消费者消费消息时消息不丢失

    一般情况下,MQ的队列中会有一个offset偏移量指向当前消费消息的位置,Consumer消费消息之后会往MQ返回一个消息,然后MQ就会把offset偏移量往前移动。如果consumer消费失败了,那么MQ的offset也不会移动,下次Consume再重新消费就行了。

    会造成消费时消息丢失才场景是:Consumer消费消息变为异步的方式,刚开始收到需要消费的消息就往MQ发送一个消息,然后再去执行本地事务,这个时候如果本地事务执行失败,可是发送给MQ的确认消息却已经发送成功了,这就造成了消费端消息丢失。

    解决消费者消息消息时不丢失的方式:

    • RocketMQ:使用默认的消费方式就行,不要采用异步方式
    • RabbitMQ:它在消费消息时有一个autocommit自动提交的机制,我们将autocommit关闭,不要让它自动提交,改为手动提交offset
    • Kafka:也是一样的改为手动提交offset

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/191426.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

软考高级系统架构师背诵要点---软件架构设计

软件架构设计 软件架构的概念: 软件架构为软件系统提供了一个结构、行为和属性的高级抽象,由构成系统的元素的描述、这些元素的相互作用、指导元素集成的模式及这些模式的约束组成 软件架构41视图: 逻辑视图:主要是整个系统的抽…

Java基础:面向对象

一、设计对象并使用 二、封装 对象代表什么,就得封装对应的数据,并提供数据对应的行为。 1.private关键字:priviate修饰的成员变量只能在本类中访问。 2.this关键字:能够直接对应成员变量(当局部变量名相同时)。 3. 构造方法…

【Linux】十分钟快速了解Linux常用指令(建议收藏)

目录💖一. 关机指令01. shutdown02. halt03. reboot💖二. 常用指令04. ls05. pwd06. cd07. touch08. mkdir09. rm10. man11. cp(复制)12. mv指令13. nano14. cat15. less16. head17. tail18. find19. grep20. zip/unzip21. tar💖三、 日期指令…

JS 中 reduce()方法及使用详解

reduce()方法可以搞定的东西特别多,就是循环遍历能做的,reduce都可以做,比如数组求和、数组求积、统计数组中元素出现的次数、数组去重等等。 reduce() 方法对数组中的每个元素执行一个由您提供的reduce函数(依次执行),将其结果汇…

Python字符串分割方法【心得总结】

Python中字符串分割的常用方法 是直接调用字符串的str.split方法, 但是其只能指定一种分隔符, 如果想指定多个分隔符拆分字符串需要用到re.split方法 (正则表达式的split方法) 源码资料电子书:点击此处跳转文末名片获取 str.spli…

OAuth2简单介绍

目录 一、什么是OAuth2 二、OAuth2中的角色 1、资源所有者 2、资源服务器 3、客户 4、授权服务器 三、认证流程 四、生活中的OAuth2思维 五、令牌的特点 六、OAuth2授权方式 1、授权码 2、隐藏式 3、密码式 4、凭证式 一、什么是OAuth2 OAuth2.0是目前使用非常广…

7个高频出现的面试题

收集了2022年所有学生的面试题后,我整理出了7个高频出现的面试题,一起来看看。 高频问题1:请自我介绍下? 高频问题2:请介绍下最近做过的项目? 高频问题3:请介绍下你印象深刻的bug? 高…

Spring Batch 步骤对象-Chunk Tasklet

引言 接着上篇:Spring Batch 步骤对象-步骤Step与Tasklet 了解step步骤概念及其使用之后,本篇再来讲解spring batch使用更广,功能更强大的tasklet:居于块的批处理步骤:Chunk Tasklet 简介 居于chunk(块)的Tasklet相…

江西/杭州/黑龙江/深圳DAMA-CDGA/CDGP数据治理认证招生简章

2023年2月江西/杭州/黑龙江/深圳DAMA-CDGA/CDGP数据治理认证招生简章 DAMA认证为数据管理专业人士提供职业目标晋升规划,彰显了职业发展里程碑及发展阶梯定义,帮助数据管理从业人士获得企业数字化转型战略下的必备职业能力,促进开展工作实践…

【笔记】质量保障体系

一、什么叫质量保障体系?质量保障体系,是指指贯穿研发流程进行的一系列质量活动。通过方案选型、策略决策、工具支撑、组织协同分工等,把质量活动进行系统化、标准化、流程化。其目的是保障业务质量。质量保障体系质量活动工具平台质量流程。二、紧贴业务…

【My Electronic Notes系列——正弦波振荡电路】

目录 序言: 🏆🏆人生在世,成功并非易事,他需要破茧而出的决心,他需要永不放弃的信念,他需要水滴石穿的坚持,他需要自强不息的勇气,他需要无畏无惧的凛然。要想成功&#…

每天10个前端小知识 【Day 1】

前端面试基础知识题 1. 什么是尾调用优化和尾递归? 尾调用的概念非常简单,一句话就能说清楚,就是指某个函数的最后一步是调用另一个函数。 function f(x){ return g(x); }上面代码中,函数f的最后一步是调用函数g,这…

Axios网络请求

哈喽~大家好,这篇来看看Axios网络请求。 ​文章推荐链接SpringCloud Sentinel 使用SpringCloud Sentinel 使用将Nacos注册到springboot使用以及Feign实现服务调用将Nacos注册到springboot使用以及Feign实现服务调用微服务介绍与 SpringCloud Eureka微服务介绍与 Sp…

Spark07: 宽窄依赖、Stage的划分

一、宽依赖和窄依赖 1. 窄依赖 窄依赖(Narrow Dependency):指父RDD的每个分区只被子RDD的一个分区所使用,例如map、filter等这些算子。 一个RDD,对它的父RDD只有简单的一对一的关系,也就是说,RDD的每个partition仅仅…

Python分支循环规范:if elif for while

分支与循环 条件是分支与循环中最为核心的点, 解决的问题场景是不同的问题有不同的处理逻辑。 当满足单个或者多个条件或者不满足条件进入分支和循环, 这里也就说明这个对相同问题处理执行逻辑依据具体参数动态变化, 由此产生多种可能性&…

GAMES101笔记:辐射度量学(下)

Irradiance 定义:irradiance是单位面积上的power,这个单位面积是和入射光线垂直的方向上的单位面积。如果受光表面不垂直于光线,需要投影到垂直方向上进行计算(cosθ\thetaθ)。 Irradiance Falloff 光的Intensity…

零入门容器云网络实战-8->veth pair设备介绍

在介绍veth pair之间,先看一下下面的图, 这类东西有没有见过? 如果没有见过,赶紧看看你方圆10米之内有没有? 这就是网线,最明显的特征是有两端!即,两个水晶头 一端可以链接普通的电脑&#…

【技术调研】关于仪表盘转图片推送钉钉的技术方案调研

方案1—纯后端实现 后端写定时任务,定时启动查询服务。查询出数据集结果,拼接成Table样式,再转换成图片。推送至钉钉。 优点:只需要后端开发,不涉及前端。 缺点:太定制化,不通用,样…

Dart语法学习-数据类型

一、Dart 语言对以下类型具有支持 Numbers (int, double) Strings (String) Booleans (bool) Lists (List, also known as arrays) Sets (Set) Maps (Map) Runes (Runes; often replaced by the characters API) Symbols (Symbol) The value null (Null) Dart 要求以 main 函数…

正大国际期货:什么是黄金保证金交易?黄金保证金交易包含哪些要点?

黄金保证金交易是指在黄金买卖业务中,市场参与者不需对所交易的黄金进行全额资金划拨,只需按照黄金交易总额支付一定比例的价款,作为黄金实物交收时的履约保证。黄金保证金交易根据类型不同,主要分为期货黄金保证金交易和现货黄金…