springBoot整合rabbitMQ --实现延时消息功能(1)

最近一直在考虑订单延时取消的功能,之前一直用的定时任务,那么有没有更好的实现方式呢?rabbitMQ 的延时消息实现则是一个很好的选择。
电商项目中针对延时这种场景有很多,比如:

  • 订单业务:在电商中,用户下单后30分钟后未付款则取消订单。
  • 下单业务:用户下单并付款后,1分钟后发短信给用户。
  • 注册业务:比如新用户注册完,5天后给予短信提醒,增加系统活跃量。

要知道rabbitMQ是AMQP协议支持的,但是他们并没有实现延时队列功能。但是我们可以通过如下两种方式实现:

  • rabbitMQ 的高级特性TTL+DLX来实现。
  • rabbitmq-delayed-message-exchange插件更简单的实现方式

方式一:TTL+DLX高级特性实现

一、何为TTL?

TTL 全称 Time To Live(存活时间/过期时间)
当消息到达存活时间后,还没有被消费,会被自动清除。
RabbitMQ可以对消息设置过期时间,也可以对整个队列(Queue)设置过期时间。

二、何为死信队列?

死信队列,英文缩写:DLX 。Dead Letter Exchange(死信交换机),当消息成为Dead message后,可以被重新发送到另一个交换机,这个交换机就是DLX。

三、实践

拿下单未付款取消订单的功能来举例:
在这里插入图片描述

方式二:rabbitmq-delayed-message-exchange插件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值