异步消息队列:
Redis 的 list(列表) 数据结构常用来作为异步消息队列使用,使用rpush/lpush操作入队列,使用lpop 和 rpop来出队列。
队列空了怎么办?
1.客户端就会陷入 pop 的死循环,可以sleep 1秒。
2.使用阻塞读:阻塞读在队列没有数据的时候,会立即进入休眠状态,一旦数据到来,则立刻醒过来。消息的延迟几乎为零。用blpop/brpop替代前面的lpop/rpop
注意:闲置过久,服务器一般会主动断开连接,减少闲置资源占用。注意异常捕获。
延时队列:
通过 Redis 的 zset(有序列表) 来实现。消息内容作为 zset 的value,到期时间作为score,用多个线程轮询获取到期的任务进行处理,多个线程是为了保障可用性,万一挂了一个线程还有其它线程可以继续处理。(使用zrem 来决定唯一的属主。确保任务不被多次执行)