在一些订单业务当中常常有一些没有支付的订单在超时之后自动删除
解决方法
redis 自动过期的实现方式是:将订单号缓存到redis当中,通过设置存活时间保证到期失效
缺点:redis过期键删除策略有有惰性删除和定期删除,惰性删除只会在使用的时候进行删除,而定期删除会定期从数据库当中找到一部分数据根据过期词典判断是否过期,但是两种都不能保证可以准时进行删除并发送通知(redis通知不可靠,也不会用)。
rocketmq实现的延时队列只支持特定的延时时间段, 30m,不能支持任意时间段的延时。
具体实现:rocketmq发送延时消息时先把消息按照延迟时间段发送到指定的队列中(rocketmq把每种延迟时间段的消息都存放到同一个队列中)然后通过一个Timer定时器进行轮训这些队列,查看消息是否到期,如果到期就把这个消息发送到指定topic的队列中,这样的好处是同一队列中的消息延时时间是一致的,还有一个好处是这个队列中的消息时按照消息到期时间进行递增排序的,说的简单直白就是队列中消息越靠前的到期时间越早