Redis Lua脚本通过KEYS和ARGV接收参数:KEYS存显式声明的key名,ARGV存动态值参数;必须用ARGV传递所有非key参数,避免拼接注入,并注意字符串类型转换与空值处理。Redis Lua脚本里怎么接收外部传进来的参数Redis 执行 EVAL 或 EVALSHA 时,Lua 脚本能拿到两个固定表:KEYS 和 ARGV。前者存 key 名(必须显式声明),后者存任意值参数------你所有「动态参数」都得走 ARGV。常见错误是把变量直接拼进 Lua 字符串里传,比如用 Python 的 f-string 把用户输入塞进脚本体,这既危险(Lua 注入)又低效(无法缓存 SHA)。正确做法是:脚本写死逻辑,参数全走 ARGV。KEYS 只能用于真正需要 Redis 命令操作的 key,且数量和顺序必须和 EVAL 命令中 key 参数严格一致ARGV 是纯数据容器,支持字符串、数字、nil(但 Redis 客户端通常把 nil 转成空字符串或丢弃)Lua 里访问参数:取第一个动态值用 ARGV[1],第二个用 ARGV[2],下标从 1 开始用 EVAL 传参时命令格式容易错在哪执行 EVAL 时,key 数量、key 列表、argv 列表三者位置和数量必须对齐,错一个就报 ERR Error running script (call to f_...): @user_script: N: user_script: N: attempt to concatenate a nil value 这类奇怪错误。典型翻车点:忘了数 key 个数,或者把本该进 ARGV 的值误塞进了 key 列表。命令结构固定为:EVAL <script> <numkeys> <key1> <key2> ... <arg1> <arg2> ...numkeys 是 key 的个数,不是总参数个数;它决定了前几个参数被放进 KEYS 表,剩下的全进 ARGV例如:执行 EVAL "return KEYS[1]..ARGV[1]" 1 mykey hello → 返回 "mykeyhello";但写成 EVAL "..." 0 mykey hello 就会让 mykey 进 ARGV[1],hello 进 ARGV[2]Lua 脚本里处理 ARGV 类型要注意什么Redis 只传字符串给 Lua,哪怕你传的是数字 123 或布尔 true,到 Lua 里都是字符串。脚本里不能直接拿 ARGV[1] > 10 比较,会出错。 标贝科技 标贝科技-专业AI语音服务的人工智能开放平台
相关推荐
QQ24221997917 分钟前
基于python+微信小程序的家教管理系统_mh3j9RSTJ_16251 小时前
PYTHON+AI LLM DAY THREETY-SEVEN阿波罗尼亚1 小时前
数据库序列(Sequence)郝学胜-神的一滴1 小时前
深度学习优化核心:梯度下降与网络训练全解析Aision_1 小时前
Agent 为什么需要 Checkpoint?清水白石0081 小时前
《Python性能深潜:从对象分配开销到“小对象风暴”的破解之道(含实战与最佳实践)》Junsir大斗师1 小时前
Nginx服务器代理Postgresql-16后端数据库Je1lyfish1 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecutionLand03292 小时前
RPA工具选型技术指南:架构差异与实测数据kafei_*2 小时前
VScode 添加 UV虚拟环境方法