背景
我们在购物平台会看到有商品开始出售的订阅通知,如xxx商品即将在xxxx-xx-xx xx:xx:xx开售,你可以点击下面的“订阅预售通知”的按钮,然后一次性订阅消息。在商品开售的前十分钟或者几分钟你将收到一次性订阅消息,提示商品将在xxxx-xx-xx xx:xx:xx开售,请注意及时参加,不要错过机会,机不可失,失不再来等。在很多电商平台都可以看见这些类似的功能,那么这些功能是怎么实现的呢?下面是笔者实现的一个简单业务实现。
设计实现
p1.1是设计的主要实现,其中主要流程如下:
- 任务推送
- 延迟队列轮询
- mq消息异步消费
任务推送
在用户点击一次性消息订阅通知后,会将触发的时间装换为毫秒并且作为score存储在redis中;
延迟队列轮询
应用程序在启动时开启一个延时任务DelayTask,延迟任务以轮询的方式拉取最近3秒内的任务,并将消息投递到mq中;
mq消息异步消费
mq消息消费者获取推送的消息,将获取的消息通过dispatch投递到任务处理池中,任务处理池由一个线程池和任务处理器组成,消息在里面被组装成对应的消息模板,通过rpc的方式完成消息通知。