方法1:定时任务轮询
实现思路:
定时任务轮询数据库,判断是否超时并更新字段
- 优点
简单易开发 - 缺点
时间不准确,以定时任务的执行间隔时间为最大时间差,比如设置定时任务30分钟执行一次,订单在上次定时任务执行结束后1秒过期,一直到经过29分钟59秒下次定时任务才能取消订单。
方法2:redis事件通知
实现思路:
- 订单生成时放订单号到redis,并设置过期时间,监听redis过期事件(即key的del事件),
- 在事件发生时候判断订单状态
- 订单已支付则不做操作
- 订单未支付则取消(删除)该订单
- 优点
开发简单,准确性尚可。 - 缺点
时间准确,可靠性得不到保证,未必能确认在过期时间在0时候一定删除。同时监听过期时间是对全局的key进行监听,因此性能损耗较大。
方法3:rabbitMq实现延迟消费
实现思路:
- 订单生成时候,生产消息,设置了30分钟后延迟消费
- 30分钟后开始消费,并判断订单状态
- 订单支付:则不取消该订单
- 订单未支付:则取消(删除)该订单
- 优点
超时时间判断准确 - 缺点
额外搭建rabbitMq,小项目不适合