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

时间:2014-09-12 04:49:56

标签: javascript node.js lua redis

我试图编写一个非常简单的Lua脚本来从node_redis访问redis中的hyperloglog功能。我有1个键和多个哈希作为要传递的元素。只有当我对密钥和参数进行硬编码时,我才能成功地执行此操作:

脚本: '返回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(script, 1, args, function (ret) {
    console.log(ret);
});

args是一个数组如下:

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

回调始终为null且服务器上没有设置密钥...不访问KEYS和ARGV数组...(正如我所说的硬编码,它工作正常..)

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

提前感谢您的帮助。

2 个答案:

答案 0 :(得分:0)

之前的答案是错误的,您需要将所有参数和值连接到单个数组(使用lodash的示例):

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

无论如何你应该考虑ioredis因为它支持lua scirpts的抽象。

答案 1 :(得分:-1)

我正在回答我自己的问题,这是aembke的评论......感谢帮助aembke!

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

呼叫评估:

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

args array:

[script, "#keys" ("1" in this case), ['key string'], ['hash1', ...., 'hash30']]