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 免费一键快速抠图,支持下载高清图片
相关推荐
DFT计算杂谈7 小时前
自动化脚本一键绘制三元化合物相图EW Frontier7 小时前
6G ISAC新范式:基于智能漏波天线的Wi‑Fi通感一体化系统设计与实测【附MATLAB+python代码】姚青&7 小时前
测试技术体系南境十里·墨染春水7 小时前
C++日志 2——实现单线程日志系统后端漫漫7 小时前
Redis 客户端工具体系易标AI8 小时前
标书智能体(五)——如何让弱模型也能稳定输出复杂jsonCyber4K8 小时前
【Python专项】Nginx访问日志分析时间范围处理示例PaperData9 小时前
1988-2025年《中国人口和就业统计年鉴》全年份excel+PDF周末也要写八哥9 小时前
代码中的注释的重要性(二)愿^O^~9 小时前
JVM GC 入门 → 进阶