【问题标题】:Getting multiple key values from Redis从 Redis 获取多个键值
【发布时间】:2012-04-26 16:15:38
【问题描述】:

我目前正在使用 Redis,我有几个问题。是否可以从键数组中获取值?

例子:

users:1:name "daniel"
users:1:age  "24"

users:2:name "user2"
users:2:age  "24"

events:1:attendees "users:1", "users:2"

当我 redis.get events:1:attendees 时,它返回 "users:1", "users:2"。我可以遍历这个列表并获取用户:1,获取用户:2。但这感觉不对,有没有办法在 1 次获取所有与会者信息?!

在rails中我会做这样的事情:

@event.attendees.each do |att|
  att.name
end

但在 redis 中我不能,因为它返回键而不是存储在该键处的实际对象。

谢谢:)

【问题讨论】:

    标签: ruby-on-rails-3 redis


    【解决方案1】:

    对项目进行循环并同步访问每个元素并不是很有效。使用 Redis 2.4,有多种方法可以做你想做的事:

    • 使用排序命令
    • 使用流水线
    • 使用可变参数命令

    在 Redis 2.6 中,您还可以使用 Lua 脚本,但这并不是真正需要的。

    顺便说一句,您描述的数据结构可以通过使用哈希来改进。您可以将用户数据分组到一个散列对象中,而不是将用户数据存储在单独的键中。

    使用排序命令

    您可以使用 Redis 排序命令在一次往返中检索数据。

    redis> set users:1:name "daniel"
    OK
    redis> set users:1:age 24
    OK
    redis> set users:2:name "user2"
    OK
    redis> set users:2:age 24
    OK
    redis> sadd events:1:attendees users:1 users:2
    (integer) 2
    redis> sort events:1:attendees by nosort get *:name get *:age
    1) "user2"
    2) "24"
    3) "daniel"
    4) "24"
    

    使用流水线

    Ruby 客户端支持流水线(即能够向 Redis 发送多个查询并等待多个回复)。

    keys = $redis.smembers("events:1:attendees")
    res = $redis.pipelined do
       keys.each do |x|
          $redis.mget(x+":name",x+":age")
       end
    end
    

    上面的代码只会在两次往返中检索数据。

    使用可变参数命令

    MGET 命令可用于一次检索多个数据:

    redis> smembers events:1:attendees
    1) "users:2"
    2) "users:1"
    redis> mget users:1:name users:1:age users:2:name users:2:age
    1) "daniel"
    2) "24"
    3) "user2"
    4) "24"
    

    这里的费用也是两次往返。如果您可以保证要检索的密钥数量有限,则此方法有效。如果没有,流水线是一个更好的解决方案。

    【讨论】:

    • 感谢您的回复!我要试试你建议的代码!谢谢:)
    【解决方案2】:

    您可以使用 Redis 的 EVAL 命令向它发送一个 Lua script,它运行一个循环“服务器端”并在一个块中返回结果。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-05-07
      • 2015-08-24
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多