+
80
-

redis如何实现延迟消息队列?

请问redis如何实现延迟消息队列?

网友回复

+
0
-

可以采用redis有序集合(sorted set)来实现;

redis有序集合,每个元素都会关联一个double类型的分数。

redis正是通过分数来为集合中的成员进行从小到大的排序。

有序集合的成员是唯一的,但分数(score)却可以重复。

总体的思路很简单,就是每一个value的score保存的是时间,也就是说,在添加一个元素时他的score是当前时间+延时的时间。轮循获取数据时,查找小于或等于当前时间的数据项,就是具体的延时消息。

还有一个问题,就是ZRANGEBYSCORE和list的pop不同,pop是取出元素并且会把元素在list中删除。ZRANGEBYSCORE只会取出数据不会把数据从sorted set中删除。

解决方法1,利用redis的事务,先ZRANGEBYSCORE取出数据,然后再用ZREMRANGEBYSCORE 把数据删除。

我知道答案,我要回答