Performance 使用redis中的lua是否可以将存储在集合中的所有键作为哈希列表返回?

Performance 使用redis中的lua是否可以将存储在集合中的所有键作为哈希列表返回?,performance,lua,redis,Performance,Lua,Redis,我有一个结构 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是否可以构建一个脚本,该脚本将迭代设置的data_type:index并以哈希列表的形式返回所有data_type:key*?我仍然在学

我有一个结构

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是否可以构建一个脚本,该脚本将迭代设置的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位hex string}'和'some_data:index:2013:05:09',其中{64位hex string}是:索引集的成员。

检查

在您的案例中,类似于以下内容的内容应该适用:

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 
  -- your code here (could be different depending on your needs)
  local key_value = redis.call("GET", "data_type:" .. key_name)
  if key_value then
    table.insert(collect, key_value)
  end 
end 
return collect

我会很快验证这一点,但这似乎是我一直在寻找的答案@TechyTimo查看和/或evalsha命令以了解如何执行它