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