RabbitMQ

支持多种语言

RM架构:

如何保证消息可靠性?

1.保证消息可以到达Exchange

异步回调(Confirums机制

步骤:开启confirms;设置confirms的异步回调(ACK/NCK)

2.保证消息可以路由到Queue

Return机制

3.保证Queue可以持久化消息

RM重启后队列中的消息依然存在

4.保证消费者可以正常消费信息

手动ACK

死信队列

死信:

1.消息被消费者拒绝,会重新放回到队列中供其他消费者消费,requeue设置为false

2.指定了队列中的消息生存时间/发送消息时设置了消息的生存时间,生存时间到了,消息没有被消费

3.队列已经到达消息的最大长度,之后路由过来的消息直接变为死信

消费者执行了ACK/reject机制,并设置requeue==false,那么消费者没有消费的信息会重新放回到队列中,并路由到死信交换机,进而放到死信队列中供消费者消费

应用:

1,基于死信队列,队列消息已经满的情况下,消息也不会丢失;

2.实现延迟消费的效果,如下订单在一定的时间内付款

延迟交换机

死信队列实现延迟消费时,如果延迟时间比较复杂,比较多,直接使用队列需要创建大量队列

RM集群

相关推荐
纪元A梦1 小时前
分布式拜占庭容错算法——权益证明(PoS)算法详解
java·分布式·算法
Two_brushes.2 小时前
C++仿RabbitMQ实现消息队列
分布式·rabbitmq
蓝色的猴子4 小时前
Kafka
分布式·kafka
linweidong11 小时前
Go开发简历优化指南
分布式·后端·golang·高并发·简历优化·go面试·后端面经
掘金-我是哪吒12 小时前
分布式微服务系统架构第142集:全栈开发
分布式·微服务·云原生·架构
咖啡啡不加糖12 小时前
雪花算法:分布式ID生成的优雅解决方案
java·分布式·后端
wyl952713 小时前
rabbitmq Fanout交换机简介
分布式·rabbitmq
Yng Forever17 小时前
实现RabbitMQ多节点集群搭建
分布式·rabbitmq
IT路旅记17 小时前
分布式锁剖析
分布式
Linda L21 小时前
Flink CDC将MySQL数据同步到数据湖
大数据·数据库·分布式·mysql·flink·kafka