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

相关推荐
workflower2 小时前
单元测试-例子
java·开发语言·算法·django·个人开发·结对编程
YuanlongWang2 小时前
C# 基础——装箱和拆箱
java·开发语言·c#
b78gb2 小时前
电商秒杀系统设计 Java+MySQL实现高并发库存管理与订单处理
java·开发语言·mysql
wb043072013 小时前
性能优化实战:基于方法执行监控与AI调用链分析
java·人工智能·spring boot·语言模型·性能优化
LXS_3573 小时前
Day 05 C++ 入门 之 指针
开发语言·c++·笔记·学习方法·改行学it
天若有情6734 小时前
Java Swing 实战:从零打造经典黄金矿工游戏
java·后端·游戏·黄金矿工·swin
etsuyou5 小时前
js前端this指向规则
开发语言·前端·javascript
lichong9515 小时前
Android studio 修改包名
android·java·前端·ide·android studio·大前端·大前端++
shizhenshide5 小时前
为什么有时候 reCAPTCHA 通过率偏低,常见原因有哪些
开发语言·php·验证码·captcha·recaptcha·ezcaptcha
lichong9515 小时前
Git 检出到HEAD 再修改提交commit 会消失解决方案
java·前端·git·python·github·大前端·大前端++