rabbitMQ

可靠性

rabbit提供了生产者确认机制,消息发送到队列以后,会给生产者返回一个回执(publish confim ack),表示消息是否处理成功

持久化处理,把消息,队列,交换机持久化

消费者取消自动回应ack,消费完在发送ack

RabbitMQ消息的重复消费问题如何解决?

我们遇到过消息重复消费的问题,当时处理的支付订单,给他设置了一个全局唯一id,再处理消息时先去数据库中查一下id是否存在,若不存在则处理消息,若存在则忽略,避免重复消费。

那你还知道其他的解决方案吗?

使用Redis分布式锁或数据库锁来确保操作的幂等性。

了解延迟队列?

延迟队列,就是死信队列中,TTL消息过期的一种,死信即不被消费的信息

RabbitMQ实现延迟队列的方法

利用消息的TTL(Time-To-Live)和死信队列(DLQ)组合

原理:为队列或消息设置TTL,当消息在队列中存活时间超过TTL值,就会变成死信。将该队列与死信交换机绑定,死信交换机再将死信路由到另一个队列(即延迟队列),消费者从这个延迟队列中获取消息进行处理。

为队列或消息设置TTL,当消息变为死信时,路由到延迟队列上消费者再从延迟队列进行处理

RabbitMQ的高可用机制了解吗?

我们项目在生产环境使用RabbitMQ集群,采用镜像队列模式,一主多从结构。

每个节点都记录了队列完整的数据,当主节点宕机时,镜像节点升为主节点保证了高可用性

相关推荐
lizz312 小时前
从 JUnit 深入理解 Java 注解与反射机制
java·开发语言·junit
编啊编程啊程5 小时前
JUC之AQS
java·开发语言·jvm·c++·kafka
孟婆来包棒棒糖~6 小时前
Maven快速入门
java·spring boot·spring·maven·intellij-idea
jingfeng5148 小时前
C++模板进阶
java·c++·算法
杨杨杨大侠9 小时前
附录 1:[特殊字符] Maven Central 发布完整指南:从零到成功部署
java·spring boot·maven
ahauedu9 小时前
AI资深 Java 研发专家系统解析Java 中常见的 Queue实现类
java·开发语言·中间件
小厂永远得不到的男人9 小时前
基于 Spring Validation 实现全局参数校验异常处理
java·后端·架构
计算机编程小咖10 小时前
《基于大数据的农产品交易数据分析与可视化系统》选题不当,毕业答辩可能直接挂科
java·大数据·hadoop·python·数据挖掘·数据分析·spark
艾莉丝努力练剑10 小时前
【C语言16天强化训练】从基础入门到进阶:Day 7
java·c语言·学习·算法