阿里云的redis使用lua脚本报错
ERR bad lua script for redis cluster, redis.call/pcall, wrong number of arguments for ‘pexpire’ command. 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进行投诉反馈,一经查实,立即删除!