RabbitMQ-如何保证消息不丢失

RabbitMQ-如何保证消息不丢失

使用场景

  1. 异步发送(验证码、短信、邮件...)
  2. MYSQL和Redis、ES之间的数据同步
  3. 分布式事务
  4. 削锋填谷
  5. ...

  1. 生产者确认机制,RabbitMQ提供了publisher confirm机制来避免消息发送到MQ过程中丢失。消息一旦发送到MQ后,会返回一个结果给发送者,表示消息是否处理成功。

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

    1. 持久化交换机
    2. 队列持久化
    3. 消息持久化,SptingAMQP中的消息默认就是持久化的。
  3. 消费者确认机制,消费者处理消息后可以向MQ发送ack回执,MQ收到ack回执后才会删除该消息,SpringAMQP支持3中模式

    1. manual,手动ack,需要在业务代码结束后,调用API发送ack
    2. auto,自动ack,由Spring检测代码是否出现异常,没有异常返回ack,抛出异常返回nack
    3. none,关闭ack,MQ假定消费者获取消息后会成功处理,因此该消息被投递后会立即删除

    一般配合重试机制使用,在消费者出现异常时利用本地重试,达到一定次数后,如果消息依然失败,将消息投递到异常交换机,交由人工处理了。

RabbitMQ-如何保证消息不丢失?

  1. 生产者确认机制,当消息成功投递到MQ后,回执一个ack,如果投递失败回执nack
  2. 消息持久化,开启消息持久化后,MQ中缓存的数据就不会丢失
  3. 消费者确认机制,当消息投递到消费者后,消费者如果成功消费那么就回执一个ack,MQ就会删除这个消息,如果出现异常那么就回执nack。如果我们配置了重试,那么重试一定次数后依旧失败,这个消息就应该被投递到异常交换机中,交由人工处理。

相关推荐
半夜修仙2 天前
RabbitMQ中如何保证消息的可靠性传输
java·分布式·中间件·rabbitmq·github·java-rabbitmq
霸道流氓气质2 天前
RabbitMQ 从零到实战:概念、配置与 Spring Boot 集成指南
spring boot·rabbitmq·java-rabbitmq
小小工匠3 天前
Redis - 缓存与数据库一致性:问题分析与解决方案
redis·缓存·性能优化·消息队列·并发
闪电悠米3 天前
黑马点评-Redis 消息队列-01_why_redis_mq
java·数据库·spring boot·redis·缓存·junit·消息队列
snow@li3 天前
RabbitMQ:详解(2026版)/ 基于 AMQP 协议的消息中间件
分布式·rabbitmq
半夜修仙3 天前
4.RabbitMQ运维
linux·运维·服务器·分布式·rabbitmq·java-rabbitmq
Fcy6484 天前
Linux下 进程间通信详解(二)System V IPC
linux·运维·消息队列·共享内存·信号量·system v
zzz_23684 天前
【RabbitMQ】面试系列 · 第三期:从线上故障到架构选型
面试·架构·rabbitmq
小碗羊肉5 天前
【RabbitMQ高级】如何保证消息的可靠性?
java·rabbitmq·java-rabbitmq
zzz_23685 天前
【RabbitMQ】面试系列 · 第四期:性能调优与插件生态
面试·rabbitmq·ruby·java-rabbitmq