4

私は構造を持っています

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 セットのメンバーです.

4

1 に答える 1

2

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 
  -- 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
于 2014-11-25T22:28:52.103 に答える