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

RabbitMQ如何保证消息不丢失?

RabbitMQ如何保证消息不丢失?

消息丢失的情况

  1. 生产者发送消息未到达交换机
  2. 生产者发送消息未到达队列
  3. MQ宕机,消息丢失
  4. 消费者服务宕机,消息丢失
生产者确认机制

解决的问题:publisher confirm机制来避免消息发送到MQ过程中消失。

当消息成功发送到MQ:会返回一个publish-confirm ack(acknowledge)

消息发送到交换机失败: publish-confirm nack

消息路由到队列失败:publish-return ack

消息失败后如何处理?

    1. 回调方法即时重发(再发一次)
    2. 记录日志(如果重发后还是失败可以记录到日志中)
    3. 保存到数据库然后定时重发,成功发送后即可删除表中的数据(再失败的话,人工解决)
持久化

保证保存在MQ中的消息不丢失。

MQ默认是内存存储消息,开启持久化功能可以确保缓存在MQ中的消息不丢失。

交换机持久化,队列持久化,消息持久化

消费者确认

处理问题:消费者导致的消息丢失问题。

消费者确认机制:消费者处理消息后可以向MQ发送ack回执,MQ收到ack回执后才会删除该消息。

SpringAMQP可以配置的三种确认模式:

manual: 手动ack

auto:自动ack。Spring检测listener代码是否异常。

none: 关闭ack,MQ假定消费者获取消息后会成功处理,因此消息投递后立即被删除。

http://www.lryc.cn/news/280507.html

相关文章:

  • Random的使用
  • 通过反射修改MultipartFile类文件名
  • Macos下修改Python版本
  • 多种采购方式下,数智化招标采购系统建设解决方案
  • Java选择排序
  • [足式机器人]Part3 机构运动学与动力学分析与建模 Ch00-1 坐标系与概念基准
  • 【金猿人物展】DataPipelineCEO陈诚:赋能数据应用,发挥未来生产力
  • 4D 毫米波雷达:智驾普及的新路径(二)
  • element plus自定义组件表单校验
  • C //练习 4-13 编写一个递归版本的reverse(s)函数,以将字符串s倒置。
  • DNS解析和主从复制
  • 光猫(无限路由器)插入可移动硬盘搭建简易版的NAS
  • SpringIOC之support模块GenericGroovyApplicationContext
  • Awesome 3D Gaussian Splatting Resources
  • 【镜像压缩】linux 上 SD/TF 卡镜像文件压缩到实际大小的简单方法(树莓派、nvidia jetson)
  • Zookeeper 和 naocs的区别
  • 2-6基础算法-快速幂/倍增/构造
  • 行业内参~移动广告行业大盘趋势-2023年12月
  • 【笔记】书生·浦语大模型实战营——第四课(XTuner 大模型单卡低成本微调实战)
  • 开源的Immich自建一个堪比 iCloud 的私有云相册和备份服务
  • SPI通信讲解
  • 本地一键部署grafana+prometheus
  • NIO核心依赖多路复用小记
  • 如何彻底卸载 Microsoft Edge?
  • JavaScript-对象-笔记
  • java 运算符 选择语句
  • CNN:Convolutional Neural Network(上)
  • 将Android应用修改为鸿蒙应用的工作
  • 03 Strategy策略
  • Python实现分位数回归模型(quantreg算法)项目实战