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

相关推荐
Sheep Shaun3 小时前
深入理解红黑树:从概念到完整C++实现详解
java·开发语言·数据结构·c++·b树·算法
每天学习一丢丢3 小时前
Spring Boot 调用泛微 E9 Token 认证 + 创建流程完整教程
java·spring boot·后端
楼田莉子3 小时前
CMake学习:入门及其下载配置
开发语言·c++·vscode·后端·学习
苦逼的老王3 小时前
《java-使用kkview+libreoffice 实现在线预览ppt、xls、doc、pdf..》
java·pdf·powerpoint
没有bug.的程序员3 小时前
Spring Boot 启动原理:从 @SpringBootApplication 到自动配置深度解析
java·spring boot·后端·python·springboot·application
jiaguangqingpanda3 小时前
Day26-20260122
java·算法·排序算法
Ahtacca3 小时前
拒绝重复造轮子:利用自定义注解封装POI,实现Java通用Excel解析
java·javascript·vue·excel
gAlAxy...3 小时前
Spring Boot 详细学习指南(上篇):核心概念 + 环境搭建 + HelloWorld 实战
java·spring boot·后端
2501_944521593 小时前
Flutter for OpenHarmony 微动漫App实战:列表项组件实现
android·开发语言·javascript·flutter·ecmascript
【赫兹威客】浩哥3 小时前
【赫兹威客】Redis安装与验证教程
开发语言·php