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. 依赖于定时任务,在数据初始化完成之前可能存在排行榜数据缺失的问题。这会导致排行榜数据无法平滑过渡,是一个很严重的问题。尤其在定时任务执行时间较长的情况下,排行榜将在相当长的时间内处于异常状态。
相关推荐
惊讶的猫17 小时前
redis分片集群
数据库·redis·缓存·分片集群·海量数据存储·高并发写
期待のcode17 小时前
Redis的主从复制与集群
运维·服务器·redis
jiunian_cn17 小时前
【Redis】渐进式遍历
数据库·redis·缓存
SoleMotive.18 小时前
谢飞机爆笑面经:Java大厂3轮12问真题拆解(Redis穿透/Kafka分区/MCP Agent)
redis·spring cloud·kafka·java面试·mcp
椰子今天很可爱18 小时前
Redis进阶
redis
jiunian_cn19 小时前
【Redis】数据库管理操作
数据库·redis·缓存
惊讶的猫19 小时前
Redis 哨兵(Sentinel)介绍
redis·redis哨兵
猫头虎19 小时前
基于信创openEuler系统安装部署OpenTeleDB开源数据库的实战教程
数据库·redis·sql·mysql·开源·nosql·database
静听山水19 小时前
Redis核心数据结构-ZSet
数据结构·redis
Dontla20 小时前
黑马大模型RAG与Agent智能体实战教程LangChain提示词——6、提示词工程(提示词优化、few-shot、金融文本信息抽取案例、金融文本匹配案例)
redis·金融·langchain