Redis怎样利用Lua为多个Key同步续期

EXPIRE无法原子续期多个key,因单命令仅支持一个key且网络异常会导致错期;必须用Lua脚本通过EVAL原子执行PEXPIRE批量续期,确保一致性。为什么 EXPIRE 不能直接用于多个 Key 的原子续期Redis 单个 EXPIRE 命令只能操作一个 key,而网络往返、客户端重试、中间失败都会导致多个 key 的过期时间不同步。比如你先对 order:123 续期,再对 order:123:lock 续期,中间若断连或超时,两个 key 就会"错期"------一个还活着,一个已过期,业务逻辑就可能出乱子。真正可靠的同步续期,必须靠服务端原子执行。Lua 脚本是唯一能保证多 key 操作在单次 Redis 执行中完成的方式。用 EVAL 执行 Lua 脚本批量续期的写法核心思路:把要续期的 key 列表和新 TTL 作为参数传入,脚本里遍历并统一调用 PEXPIRE(推荐用毫秒级,精度更高、避免秒级截断误差)。EVAL "for i=1,#KEYS do redis.call('PEXPIRE', KEYSi, ARGV1) end" 2 order:123 order:123:lock 30000KEYS 是 key 列表,ARGV1 是统一的新过期毫秒数(如 30000 表示 30 秒)注意:第一个数字 2 是 key 的数量,必须和实际传入的 key 个数一致,否则报错 ERR Error running script (call to f_...): @user_script:1: WRONGTYPE Operation against a key holding the wrong kind of value如果某个 key 不存在,PEXPIRE 返回 0,不影响其他 key,脚本继续执行续期前要不要先检查 key 是否存在?大多数场景下不用。续期动作本身是"保活",不是"创建"。如果 key 已被删,PEXPIRE 返回 0,脚本照常结束,客户端可据此判断是否需重建资源。强行加 EXISTS 判断反而增加复杂度,且无法规避"检查后被删"的竞态。但有例外:如果你依赖 key 存在作为业务状态标识(比如 user:456:session 必须存在才允许续期),那就得在脚本里显式判断: Vozo Vozo是一款强大的AI视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。

相关推荐
一个天蝎座 白勺 程序猿7 小时前
时序大模型云服务快速上手:定义与核心能力
数据库·iotdb·云服务·timechoai
sukioe7 小时前
Redis 数据类型入门:5 大核心类型与常见业务场景
数据库·redis·缓存
学地理的小胖砸7 小时前
【批量处理tiff文件生成jpg缩略图】
数据库·人工智能·python
承渊政道7 小时前
【MySQL数据库学习】(MySQL数据类型)
数据库·学习·mysql·ubuntu·bash·数据库开发·数据库系统
机汇五金_7 小时前
通信设备防雨箱如何兼顾防护与散热?
网络·python
梦想的颜色7 小时前
MySQL 三大日志:Redo Log、Undo Log 和 Binlog 完全解析
数据库·mysql·数据库架构
糖果店的幽灵8 小时前
LangChain 1.3 完全教程:从入门到精通-Part 7: Documents(文档处理)
java·python·langchain
KaMeidebaby8 小时前
卡梅德生物技术快报|蛋白修饰调控 NETosis 分子机制及实验研究进展
前端·数据库·人工智能·算法·百度
Wonderful U8 小时前
基于Python爬虫+Django的轻量化天气预报系统:从数据抓取到可视化展示的完整实战
爬虫·python·django
lqjun08278 小时前
PyTorch梯度计算
人工智能·pytorch·python