Bootstrap

延时队列

异步消息队列:

Redis 的 list(列表) 数据结构常用来作为异步消息队列使用,使用rpush/lpush操作入队列,使用lpop 和 rpop来出队列。

队列空了怎么办?

1.客户端就会陷入 pop 的死循环,可以sleep 1秒。

2.使用阻塞读:阻塞读在队列没有数据的时候,会立即进入休眠状态,一旦数据到来,则立刻醒过来。消息的延迟几乎为零。用blpop/brpop替代前面的lpop/rpop

注意:闲置过久,服务器一般会主动断开连接,减少闲置资源占用。注意异常捕获。

延时队列:

通过 Redis 的 zset(有序列表) 来实现。消息内容作为 zset 的value,到期时间作为score,用多个线程轮询获取到期的任务进行处理,多个线程是为了保障可用性,万一挂了一个线程还有其它线程可以继续处理。(使用zrem 来决定唯一的属主。确保任务不被多次执行)

;