我有一个结构
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 bit hex string}' 和 'some_data:index:2013:05:09' 其中 {64 bit hex string} 是 :index 集的成员.