RabbitMQ高级:延迟消息

什么是延迟消息

其实就是如果支付服务确实不能通知交易服务去修改订单状态,那就让交易服务等30分钟,30分钟之后,如果交易服务还没有通知,就会主动去查支付服务,如果查到已支付,就更新订单状态,保证一致性。如果查到未支付,说明订单支付超时,直接取消订单。所以就需要一个延迟消息,要在下单那一刻发送,延迟一定时间后发给交易服务通知其去查支付服务。

死信交换机

利用了成为死信的第二个条件,过期消息。也就是publisher发送一个设置了TTL的消息到normal.queue,然后这个队列通过dead-letter-exchange属性指定了dlx.direct交换机,由于normal.queue没有消费者,所以这个消息在MQ里TTL过期之后,就会投递到dlx.direct,从而投递到consumer,实现了延迟消息。注意这里normal的交换机和队列的BindingKey要和dlx的交换机和队列的BindingKey一致,不然消息传不过去。

这是声明一个绑定了死信交换机的队列,也就是normal.queue。

复制代码
@Test
void testSendDelayMessage() {
    rabbitTemplate.convertAndSend("normal.direct", "hi", "hello", new MessagePostProcessor() {
        @Override
        public Message postProcessMessage(Message message) throws AmqpException {
            message.getMessageProperties().setExpiration("10000");
            return message;
        }
    });
}

这个是发送带TTL消息的代码,convertAndSend方法最后还可以带一个参数,叫做消息后置处理器,可以在Java对象转换为消息对象之后,对消息做处理。需要实现postProcessMessage方法,这个方法的形参就是转换后的消息,可以给它设置参数。

延迟消息插件

给RabbitMQ装了插件之后,就是设置个delayed属性,这个交换机就有了延迟消息的功能。

发消息也不一样了,变成setDelay了。

取消超时订单

这里是假设最坏情况,支付服务无法向MQ发送消息。

为啥要先查询本地订单状态呢,这是因为,如果本地订单状态是已支付,说明支付服务成功通知到交易服务了。交易服务自己发自己收。

相关推荐
qq_12498707533 小时前
基于Hadoop的信贷风险评估的数据可视化分析与预测系统的设计与实现(源码+论文+部署+安装)
大数据·人工智能·hadoop·分布式·信息可视化·毕业设计·计算机毕业设计
洛豳枭薰5 小时前
消息队列关键问题描述
kafka·rabbitmq·rocketmq
Coder_Boy_5 小时前
基于Spring AI的分布式在线考试系统-事件处理架构实现方案
人工智能·spring boot·分布式·spring
袁煦丞 cpolar内网穿透实验室7 小时前
远程调试内网 Kafka 不再求运维!cpolar 内网穿透实验室第 791 个成功挑战
运维·分布式·kafka·远程工作·内网穿透·cpolar
人间打气筒(Ada)7 小时前
GlusterFS实现KVM高可用及热迁移
分布式·虚拟化·kvm·高可用·glusterfs·热迁移
xu_yule7 小时前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式
難釋懷11 小时前
分布式锁的原子性问题
分布式
ai_xiaogui12 小时前
【开源前瞻】从“咸鱼”到“超级个体”:谈谈 Panelai 分布式子服务器管理系统的设计架构与 UI 演进
服务器·分布式·架构·分布式架构·panelai·开源面板·ai工具开发
凯子坚持 c12 小时前
如何基于 CANN 原生能力,构建一个支持 QoS 感知的 LLM 推理调度器
分布式