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假定消费者获取消息后会成功处理,因此消息投递后立即被删除。

相关推荐
别或许10 分钟前
python中的异步调用(直接使用教程)
java·前端·python
ShineWinsu12 分钟前
对于C++:模版初阶的解析
开发语言·c++·面试·笔试·函数··模版
CodeAmaz17 分钟前
文件断点续传完整方案
java·文件断点上传
Max_uuc17 分钟前
【C++ 硬核】告别 Excel 生成数组:利用 constexpr 实现编译期计算查找表 (LUT)
开发语言·c++·excel
像少年啦飞驰点、17 分钟前
零基础入门 Spring Boot:从‘Hello World’到可部署微服务的完整学习路径
java·spring boot·web开发·编程入门·后端教程
m0_7482486524 分钟前
C++正则表达式攻略:从基础到高级应用
java·c++·正则表达式
墨雨晨曦8824 分钟前
leedcode刷题总结
java·开发语言
嫂子开门我是_我哥28 分钟前
第十六节:异常处理:让程序在报错中稳定运行
开发语言·python
qq_124987075334 分钟前
基于SpringBoot的闪电队篮球俱乐部管理系统的设计与开发(源码+论文+部署+安装)
java·数据库·spring boot·后端·spring·毕业设计·计算机毕业设计
a努力。34 分钟前
中国邮政Java面试被问:MySQL的ICP(索引条件下推)优化原理
java·开发语言·数据仓库·面试·职场和发展·重构·maven