使用Lua脚本将多个HMSET复制到Redis

时间:2017-01-20 10:21:43

标签: lua redis redisclient

由于性能的原因,我需要尽量减少Redis的跳数。我从C ++代码多次调用HMSET,我正在研究是否可以通过使用Lua脚本来更改它,并通过一次调用Redis来设置多个Redis哈希键:

HMSET myhash1 field1 "Hello" field2 "World"
HMSET myhash2 field1 "Hello" field2 "World"
HMSET myhash3 field1 "Hello" field2 "World"
...
HMSET myhashN field1 "Hello" field2 "World"

如何将多个哈希键和多个字段/值传递给脚本?

更新 基于Itamar Haber评论,我发现我的问题是逗号和KEG和ARGV值之间缺少空格 -

我最终得到了以下脚本:

local k = 1 
for i=1,  #KEYS do
    if redis.call('hmset', KEYS[i], ARGV[k], ARGV[k+1], ARGV[k+2], ARGV[k+3]) == 1 then
        return 1
    end 
    k = k + 4 
end                                                                                                                                                                                             
return 0

redis-cli --eval /var/tmp/script.lua myhash1 myhash2 , field1 "Hello" field2 "World" field1 "Hello" field2 "World"

我不确定是否可以进一步优化以避免重复字段名称或为每个键传递任意数量的字段/值。

2 个答案:

答案 0 :(得分:2)

为了最大限度地减少跳数,您可以使用流水线技术 - 更简单并且具有所需的效果。

脚本也可以最小化跳数。使用KEYS数组将哈希键名称传递给脚本和ARGV数组以提供字段和值。

答案 1 :(得分:1)

我在另一个问题in Lua, how can I use a table as varargs (...)?中找到了答案。

所以我只使用

redis.call('hmset', KEYS[i], table.unpack(ARGV) )

这对我有用。