我们的QQ群606700249有人提到 如下问题 处理类似于12306订单30分钟自动取消?
做个redis hash结构的 ( 用户 id, 订单号id, value是个对象obj ) , 对象包含订单的信息,这个对象加一个失效日期字段,每次查询的时候发现这条记录 失效了 ,插入msyql 中, redis里面删掉这个记录 (或者不删除,修改obj订单状态的字段)
这样就不需要定时检索轮询,redis自身 缓存失效机制 两种,一种是定时检索失效,另一种就是查询时候失效剔除
--------------
根据你们的需求调整 上面只是一个思路,比如redis 是否要删除数据,你们是否准备全部从redis查 还是从mysql查 (redis 和mysql 同步)
另外如果压力不大 你们可以都存到mysql 里面 加一个时间失效字段,查询的时候判断是否失效,修改订单状态, 这样也不需要定时轮询做失效.
20180613 更新本文 除了上面的方案
可以考虑使用延时队列 了解一下 延时队列 有惊喜
参考
延时处理 延时队列 (线程池) (100ms,1s,5s 越来越大,因为对方服务可能出问题了)
可以参考:
java延迟队列
https://blog.csdn.net/superdog007/article/details/53944884
延迟队列DelayQueue
https://www.cnblogs.com/tietazhan/p/6632468.html
分布式延迟消息队列讨论
https://www.cnblogs.com/yx1989/p/7000503.html
基于redis的延迟消息队列设计
https://www.cnblogs.com/peachyy/p/7398430.html
newScheduledThreadPool延时任务线程池,实现原理
https://blog.csdn.net/lisuyibmd/article/details/53085368