【开发经验】redis排行榜功能(日榜、周榜、月榜)


前言

      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 WITHSCORES
1) "zhaoliu"
2) "2"
3) "wangwu"
4) "5"
5) "lisi"
6) "8"
7) "zhangsan"
8) "10"

获取直播间前三名进行展示,按照分值排序
      ZREVRANGE 命令返回有序集中,指定区间内的成员。其中成员的位置按分数值递减(从大到小)来排列。具有相同分数值的成员按字典序的逆序(reverse lexicographical order)排列。

ZREVRANGE key start stop [WITHSCORES]

127.0.0.1:6379> ZREVRANGE broadcast:20210108231 0 2
1) "zhangsan"
2) "lisi"
3) "wangwu"

4、查看直播间人数

ZCARD key 返回集合数量。

127.0.0.1:6379> zcard  broadcast:20210108231
(integer) 4

5、离开直播间

张三离开直播间,则删除对应key。
ZREM [key] [value]

127.0.0.1:6379>  ZREM broadcast:20210108231 zhangsan
(integer) 1
127.0.0.1:6379>  ZREVRANGE broadcast:20210108231 0 2
1) "lisi"
2) "wangwu"
3) "zhaoliu"

6、周榜

      真实场景中肯定会有时间段的划分,例如查看日榜、周榜、月榜。只需要按照最小的单位按照时间区分成不同的集合,最后求出这些集合的并集即可。
在这里插入图片描述
ZADD hotnews:1 10 zhangsan
ZADD hotnews:1 10 lisi
ZADD hotnews:2 5 zhangsan
ZADD hotnews:2 5 wangwu
如此,得到两个zset集合,最后得到两个集合的并集。
ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

127.0.0.1:6379> ZUNIONSTORE hotnews:week:1 2 hotnews:1 hotnews:2
(integer) 3
127.0.0.1:6379> ZRANGE hotnews:week:1 0 -1 WITHSCORES
1) "wangwu"
2) "5"
3) "lisi"
4) "10"
5) "zhangsan"
6) "15"

      WEIGHTS 可以设置每个集合的权重,意为在原来集合分数乘权重得到输出集合的值。
两个集合并集时,如果有相同的key,则可以通过 SUM|MIN|MAX 进行控制。默认为SUM

猜你喜欢

转载自blog.csdn.net/qq_30285985/article/details/112382087