Redis实现滚动周榜|滚动榜单|直播间榜单|排行榜|Redis实现日榜04

上述文章主要探讨了实现滚动榜单的两种方式。第一种方式是同步写n天滚动榜单,但这种方式存在一个严重的缺点:每天都需要编写多个榜单。尽管在实现三天或七天滚动榜单时相对简单,但若要实现近30天的滚动榜单,这种方式显得不够智能。因此,本文提出了一种新的实现滚动榜单的方式。

具体实现如下:

1.编写当日榜单:将当日主播礼物收益命名为榜单,并进行存储。

例如:

以下是用户ID为Test0001的用户在获得价值为13140的礼物时,增加今日榜单同时需要增加下面2的滚动榜单:

java 复制代码
//今日榜单的key定义为:gift_list_cache:20231226
redis.zincrby("gift_list_cache:20231226", 13140, "Test0001");

2.创建当日滚动榜单:以日期命名,建立一个记录当日主播礼物收益的滚动榜单(后续定时任务将使用该榜单进行合并)。

java 复制代码
//今日滚动榜单的key定义为:gift_list_cache_scroll:20231226
redis.zincrby("gift_list_cache_scroll:20231226", 13140, "Test0001");

3.定时任务处理榜单:每天凌晨0点,将前六天的榜单合并,形成一个新的临时榜单,然后将该榜单中的数据合并至当日滚动榜单中。这样,就实现了滚动更新榜单的功能。

java 复制代码
//合并前6日榜单
ZUNIONSTORE today_temporary 6 gift_list_cache_scroll:20231226 gift_list_cache_scroll:20231225 gift_list_cache_scroll:20231224 gift_list_cache_scroll:20231223 gift_list_cache_scroll:20231222 gift_list_cache_scroll:20231221

4.把这个临时榜单的数据合并到今日的滚动榜单中,这样今日榜单中的数据就是近七天的主播礼物收益数据。

注意:这里最好用java代码遍历临时榜单today_temporary的所有元素,然后zincrby到gift_list_cache_scroll:20231226之中。

通过以上方式,可以更加智能地实现滚动榜单,避免了每天都需要编写多个榜单的麻烦。

这种滚动榜单实现方式的优点:

  1. 简单易实现,只需编写少量代码,并使用两个固定的关键字来获取当天滚动榜的数值。

这种滚动榜单实现方式的缺点:

  1. 依赖于定时任务,在数据初始化完成之前可能存在排行榜数据缺失的问题。这会导致排行榜数据无法平滑过渡,是一个很严重的问题。尤其在定时任务执行时间较长的情况下,排行榜将在相当长的时间内处于异常状态。
相关推荐
fat house cat_1 小时前
【redis】线程IO模型
java·redis
敖云岚2 小时前
【Redis】分布式锁的介绍与演进之路
数据库·redis·分布式
让我上个超影吧5 小时前
黑马点评【基于redis实现共享session登录】
java·redis
懒羊羊大王呀8 小时前
Ubuntu20.04中 Redis 的安装和配置
linux·redis
John Song10 小时前
Redis 集群批量删除key报错 CROSSSLOT Keys in request don‘t hash to the same slot
数据库·redis·哈希算法
Zfox_19 小时前
Redis:Hash数据类型
服务器·数据库·redis·缓存·微服务·哈希算法
呼拉拉呼拉19 小时前
Redis内存淘汰策略
redis·缓存
咖啡啡不加糖1 天前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存
MickeyCV1 天前
使用Docker部署MySQL&Redis容器与常见命令
redis·mysql·docker·容器·wsl·镜像
肥仔哥哥19301 天前
springCloud2025+springBoot3.5.0+Nacos集成redis从nacos拉配置起服务
redis·缓存·最新boot3集成