如何用 Redis 实现延迟队列?
- 前言 -
我们都知道Redis是一种基于内存的单进程单线程数据库(Redis6.0开始之后支持多线程啦! ),处理速度都非常快。 那么为何Redis又能慢呢? 原来,这里说的慢是指Redis可以设置一些参数达到慢处理的结果。
那接下来开始讲讲我们的Redis在队列中如何实现延时的情况:
在我们日常生活中,我们可以发现:
在淘宝、京东等购物平台上下单,超过一定时间未付款,订单会自动取消。
打车的时候,在规定时间没有车主接单,平台会取消你的单并提醒你暂时没有车主接单。
点外卖的时候,如果商家在10分钟还没接单,就会自动取消订单。
收快递的时候,如果我们没有点确认收货,在一段时间后程序会自动完成订单。
在平台完成订单后,如果我们没有在规定时间评论商品,会自动默认买家不评论。
……
这时,我们可以想想为什么要这样做?
因为这样可以保证商品的库存可以释放给其他人购买,你可以不用一直等待打车却得不到回复,你可以及时换一家店点到外卖。
- 设计与实现 -
那么这些情况都是如何实现的呢?
这时我们可以看看这个图,来看看消息延迟是如何处理的:
当用户发送一个消息请求给服务器后台的时候,服务器会检测这