redis中有一个有序集合(sorted set),通过此数据结构可以很轻松的实现排行榜的功能,例如直播中的排行榜,今日头条的热度榜等等。笔者阐述下实现思路,请大家参考。如有疑问请留言。
一、redis实现排行榜
Redis 有序集合和集合一样也是 string 类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。有序集合的成员是唯一的,但分数(score)却可以重复。正是因为有分值,所以很适合用在排行榜的功能中。此以直播的排行榜为例。
每个直播间都有粉丝的排行榜,可以通过key+直播间id来作为redis的key。例如broadcast:20210108231。每个直播间的观众按照点赞数排序。则观众刚刚进入直播间即可通过ZADD添加排行榜。
1、新增操作
张三观众进入直播间。
李四进入直播间
ZADD [key] [score] [value]
ZADD broadcast:20210108231 1 zhangsan
ZADD broadcast:20210108231 1 lisi
王五进入直播间。
赵六进入直播间。
ZADD broadcast:20210108231 1 wangwu
ZADD broadcast:20210108231 1 zhaoliu
2、加分值
李四送了直播间两颗小红心。李四分值加2。
ZINCRBY [key] increment [member]
ZINCRBY broadcast:20210108231 2 lisi
3、展示榜单
通过如上指令对直播间分值进行设置之后,得到redis的value如下:
127.0.0.1:6379> ZRANGE broadcast:20210108231 0 -1 WI