使用node_redis客户端正确执行Lua脚本

我试图编写一个非常简单的Lua脚本,以从node_redis访问redis中的hyperloglog功能。我有1个密钥和多个散列作为要传递的元素。只有在硬编码密钥和参数的情况下,我才能成功实现这一点,如下所示:

脚本: 'return redis.call("pfadd",'testkey','valvalval')'

虽然这很完美,但这并不是非常有用...

我已经尝试了我能想到的所有可能的访问KEYS和ARGV数组的方法,这是我在.js文件中拥有的内容:

var script = '\
local val = 0 \
for _, hash in pairs(ARGV) do \
     redis.call("pfadd", KEYS[1], hash) \
end \
return val';

要调用我的脚本:

redisInstance.eval(脚本,1,args,functionret){
    console.logret);
});

args是以下数组:

['key''hash1''hash2''hash3',...,'hash30']

回调始终为空,并且服务器上没有设置键...不访问KEYS和ARGV数组...(当硬编码时,它正常工作..)

我需要将所有散列作为元素传递(每次总共约30)并接收整数回复。

提前感谢您的帮助。

点赞
用户3311886
用户3311886

我在回答aembke的评论,并感谢他的帮助!

var script =
'\
local val = 0 \
for _,hash in pairs(ARGV) do \
  val = tonumber(redis.call("pfadd", KEYS[1], hash)) \
end \
return val';

调用 eval:

redisInstance.eval(args, function(err, res){
    //使用 res
})

args 数组:

[script, "#keys" ("1" in this case), ['key string'], ['hash1', ...., 'hash30']]
2014-09-12 16:42:05
用户2318467
用户2318467

上一个答案是错误的,你需要将所有参数和值连接成一个单一的数组(使用lodash进行示例):

var keys = _.keys(filteredData);
var values = _.values(filteredData);
var command = ["function code",keys.length];
command = command.concat(keys,values);

无论如何,你应该考虑使用ioredis,因为它支持lua脚本的抽象。

2015-11-09 19:19:16