在Redis中,是否可以使用Lua返回一个集合中所有存储的键作为哈希列表?

我有一个结构体

data_type:key1 - hash
data_type:key2 - hash
data_type:key3 - hash
data_type:key4 - hash
data_type:key5 - hash
data_type:index - set(key1, key2, key3, key4, key5)

在redis中使用lua编写一个脚本,在遍历set data_type:index并将所有data_type:key*返回为哈希列表。 我还在学习Lua,所以我认为它应该像这样工作

collect = []
for key_name in redis.call.smemembers('data_type:index'):
    collect.append( redis.call.smembers('data_type:' + key_name)
return collect

一般来说,大多数索引具有约100个键,每个键约为1KB,因此在理想情况下,此脚本将具有100-120KB的响应大小。

在任何人提问之前,真正的键看起来像“some_data:status:{64位十六进制字符串}”和“some_data:index:2013:05:09”,其中{64位十六进制字符串}是:index set的成员。

点赞
用户1058509
用户1058509

查看 SSCAN 命令

在你的情况下,类似以下的代码应该可行:

local collect = {}
local match_pattern = "*"
local results = redis.call("SSCAN", "data_type:index", 0, "match", match_pattern)
for i, key_name in ipairs(results[2]) do
  -- 根据需要编写的代码
  local key_value = redis.call("GET", "data_type:" .. key_name)
  if key_value then
    table.insert(collect, key_value)
  end
end
return collect
2014-11-25 22:28:52