由于性能的原因,我需要尽量减少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"
我不确定是否可以进一步优化以避免重复字段名称或为每个键传递任意数量的字段/值。
答案 0 :(得分:2)
为了最大限度地减少跳数,您可以使用流水线技术 - 更简单并且具有所需的效果。
脚本也可以最小化跳数。使用KEYS
数组将哈希键名称传递给脚本和ARGV
数组以提供字段和值。
答案 1 :(得分:1)
我在另一个问题in Lua, how can I use a table as varargs (...)?中找到了答案。
所以我只使用
redis.call('hmset', KEYS[i], table.unpack(ARGV) )
这对我有用。