Redis如何清理过期排行数据_利用ZREMRANGEBYSCORE移除ZSet历史记录

ZREMRANGEBYSCORE 清不掉过期 ZSet 数据,根本原因是 Redis 的 ZSET 不自动感知过期,需用时间戳作 score 并手动按时间范围删除。为什么 ZREMRANGEBYSCORE 清不掉过期的 ZSet 数据?根本原因不是命令用错了,而是时间戳没对齐。Redis 的 ZSET 本身不自动感知"过期",你得自己把"过期"定义成一个分数范围------比如用 Unix 时间戳当 score,过期就是 score 。如果存进去的 score 是毫秒时间戳,但清理时用的是秒级 <code>time.time(),那大概率漏删。确认写入时用的是秒还是毫秒:查一条数据,执行 ZRANGE key 0 0 WITHSCORES 看 score 值量级(10 位是秒,13 位是毫秒)清理前先算准当前时间戳单位,Python 里 int(time.time()) 是秒,int(time.time() * 1000) 是毫秒别用 0 当下界------万一有人手动塞了负分,ZREMRANGEBYSCORE key -inf (now) 才安全用 ZREMRANGEBYSCORE 清理排行榜历史数据的正确姿势排行榜场景常见"只保留最近 7 天活跃用户",这时 score 应该是最后活跃时间戳。清理不是删全量,而是切片删------一次别删太多,避免阻塞主线程。命令格式固定:ZREMRANGEBYSCORE key -inf (timestamp),括号表示开区间,(timestamp) 表示"严格小于 timestamp"建议每次最多删 1000 条:先 ZCOUNT key -inf (timestamp) 预估数量,超了就分批,用 ZREMRANGEBYSCORE key -inf (timestamp) LIMIT 0 1000(注意:LIMIT 在 Redis 7.0+ 才支持,旧版本只能靠客户端循环)别在高峰期直接跑全量清理------加个 SCAN 式渐进清理逻辑,或改用后台任务轮询ZREMRANGEBYSCORE 和 EXPIRE 能不能一起用?不能混用目标。Redis 的 EXPIRE 是 key 级过期,对 ZSET 整体生效;而 ZREMRANGEBYSCORE 是成员级清理。你要的是"榜单里的人过期就下榜",不是"整个榜单消失"。给 ZSet 设 EXPIRE 只会让整个结构被删,和业务逻辑冲突。 灵办AI 免费一键快速抠图,支持下载高清图片

相关推荐
m0_377618232 小时前
Angular 响应式导航栏:纯 Angular 实现移动端菜单折叠与展开
jvm·数据库·python
毅炼2 小时前
MySQL常见问题总结(2)
java·数据库·mysql
李松桃2 小时前
音乐爬虫 - Python
开发语言·python·python实操
2401_897190552 小时前
mysql数据库性能基准测试工具推荐_使用sysbench进行压力测试
jvm·数据库·python
爱喝水的鱼丶2 小时前
SAP-ABAP: 深入浅出 SAP 经典可执行程序:从零开始掌握
运维·服务器·数据库·sap·abap·开发交流
Irene19912 小时前
Python 学习途径,从熟悉的 JavaScript 过渡到 Python
javascript·python
迷藏4942 小时前
**RISC-V生态下的嵌入式开发新范式:从指令集到自定义外设的全流程实战**在当前国产化
java·python·risc-v
F_windy2 小时前
大模型应用开发学习路径<JAVA转型赋能>
python·深度学习·数据分析
Shorasul2 小时前
mysql如何处理由于网络抖动导致的复制断开_mysql重试机制配置
jvm·数据库·python