RabbitMQ问题

如何实现顺序消费?

消息放入到同一个队列中消费

如何解决消息不丢失?

方案:

如上图:消息丢失有三种情况,解决了以上三种情况就解决了丢失的问题

1、丢失1--->消息在到达交换机的时候;解决:MQ需要开启确认模式

2、丢失2--->在MQ内容丢失的问题;解决:开启消息持久化(交换机设置,队列设置)

3、丢失3--->消息抵达消费者的时候;解决:消费者开始手动ACK

如何解决消费积压?

1、多队列,根据不同消息类型放在不同队列

2、多消费者,根据消息的类型和优先级分配消费者

3、设置TTL,不能无限制阻塞,设置过期时间

如何解决消息重复?

原因:

1、生产者发送消息到MQ,但是由于网络波动,MQ没有回复,生产者又重新发送了一次

2、MQ消息到达消费者时,由于网络波动,没有回复,MQ又重新发送了一次

方案:幂等性

1、消息传递时,需要携带一个唯一ID,将此ID存到redis中

2、接收到消息,先去redis中查,如果有则直接丢弃此消息,如果没有正常消费,将该ID存redis设置TTL

相关推荐
往事随风去3 天前
架构师必备思维:从“任务队列”到“事件广播”,彻底吃透消息队列两大设计模式
消息队列·rabbitmq
虫小宝4 天前
返利app的消息队列架构:基于RabbitMQ的异步通信与解耦实践
分布式·架构·rabbitmq
无缘之缘4 天前
SpringBoot整合RabbitMQ
spring boot·rabbitmq·java-rabbitmq
葵野寺5 天前
【RelayMQ】基于 Java 实现轻量级消息队列(九)
java·开发语言·rabbitmq·java-rabbitmq
Cxzzzzzzzzzz5 天前
RabbitMQ 在实际开发中的应用场景与实现方案
分布式·rabbitmq
优秀的老黄6 天前
Docker部署RabbitMQ
linux·运维·docker·中间件·容器·centos·rabbitmq
java1234_小锋6 天前
RabbitMQ如何实现消息的持久化?
java·rabbitmq·java-rabbitmq
AD钙奶-lalala6 天前
RabbitMQ的核心使用示例
java·rabbitmq·java-rabbitmq
山城码农笑松哥6 天前
国产凝思debian系Linux离线安装rabbitmq教程步骤
linux·debian·rabbitmq
小句6 天前
RabbitMQ对接MQTT消息发布指南
分布式·rabbitmq·ruby