rabbitMQ

可靠性

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

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

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

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

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

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

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

了解延迟队列?

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

RabbitMQ实现延迟队列的方法

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

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

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

RabbitMQ的高可用机制了解吗?

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

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

相关推荐
JH30738 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
Coder_Boy_9 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble9 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟9 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖10 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
qq_124987075311 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_11 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.11 小时前
Day06——权限认证-项目集成
java
瑶山11 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
abluckyboy11 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法