rabbitMQ

可靠性

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

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

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

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

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

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

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

了解延迟队列?

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

RabbitMQ实现延迟队列的方法

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

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

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

RabbitMQ的高可用机制了解吗?

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

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

相关推荐
JAVA面经实录91718 分钟前
操作系统(面试全覆盖)
java·计算机网络·面试
编程的一拳超人34 分钟前
Maven 国内高速镜像推荐(按速度排序)
java·maven
云烟成雨TD1 小时前
Spring AI 1.x 系列【61】Spring AI 2.0 升级指南
java·人工智能·spring
lulu12165440782 小时前
OpenRouter Fusion 多模型融合架构深度拆解:预算级模型组团打平 Fable 5,多模型协作才是 AGI 的正确打开方式?
java·人工智能·架构·ai编程·agi
雨辰AI2 小时前
生产级实测:SpringBoot3 + 达梦数据库接口从 200ms 优化至 20ms 完整调优指南
java·数据库·spring boot·后端·政务
(Charon)2 小时前
【C++ 面试高频:内存管理、RAII 和智能指针详解】
java·开发语言·word
凡人叶枫3 小时前
Effective C++ 条款39:明智而审慎地使用 private 继承
java·数据库·c++·嵌入式开发
轻刀快马3 小时前
跨越软硬件的共鸣(二):从 Cache 写策略看 Redis 与 DB 的一致性博弈
java·开发语言·redis·计算机组成原理
折哥的程序人生 · 物流技术专研3 小时前
Java 23 种设计模式:从踩坑到精通 | 装饰器模式 —— 比继承更灵活的扩展方式,你用过吗?
java·装饰器模式·java面试·结构型模式·java设计模式·javaio·从踩坑到精通