阿里云的redis使用lua脚本报错

ERR bad lua script for redis cluster, redis.call/pcall, wrong number of arguments for ‘pexpirecommand. channel:

org.redisson.client.RedisException: ERR bad lua script for redis
cluster, redis.call/pcall, wrong number of arguments for ‘pexpire
command. channel: [id: 0xec112fb5, L:/ – Rcommand: (EVAL), promise:
java.util.concurrent.CompletableFuture@28a11e11[Not completed, 1
dependents], params: [local result = 0;for j = 1, #KEYS, 1 do local
expireSet; if ARGV[2] ~= ‘’ then expireSet = redis.call(‘pexpire’,
KEYS[j], ARGV[1], ARGV[2]); else expireSet = redis.call(‘pexpire’,
KEYS[j], ARGV[1]); end; if expireSet == 1 then result = expireSet;end;
end; return result; , 1, ooooooo, 22604000, ]

解决办法

默认阿里云Redis会对lua脚本做一定限制,目的是为了保证脚本里面的所有操作都在相同slot进行,如果用户能够代码确保所有操作都在相同slot而又想打破Redis集群的lua限制的话可以通过控制台修改script_check_enable参数为0,则后端不会对脚本进行校验

原文地址:https://blog.csdn.net/jerryyang_2017/article/details/129246903

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_35954.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注