performance - 可能在 redis 中使用 lua 将存储在集合中的所有 key 作为哈希列表返回?

标签 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* 作为哈希列表返回?我仍在学习 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}是:索引集。

最佳答案

检查 SSCAN command .

类似下面的内容应该适用于您的情况:

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

关于performance - 可能在 redis 中使用 lua 将存储在集合中的所有 key 作为哈希列表返回?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16465354/

相关文章:

c++ - OpenCV Python 通过图像数据绑定(bind)非常慢的迭代

Emacs lua-mode(文件模式规范错误)

java - 这是什么服务器端编程语言?

spring-boot - Spring Data Redis 与 Spring Session Data Redis

java - 检查数组中所有元素是否相等的最快方法

android - 图像的密度无关(倾角)大小变化很大

css - 在网络上加载高分辨率图像是否有良好的非阻塞模式?

python - 从 C++ 调用 Python 或 Lua 来计算表达式,仅在需要时计算未知变量

redis - 如何在群集中禁用redis复制

ruby-on-rails - 当为 kvs 使用 redis 时,使用 1 db 或不同的是很快的