充分利用Redis的多个键值(Getting multiple key values from Re

2019-06-23 15:17发布

我目前正在玩弄的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次得到的所有参加者信息?

在铁轨我会做这样的事情:

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

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

谢谢 :)

Answer 1:

对项目做一个循环,并同步访问每个元素是不是很有效。 随着Redis的2.4,有各种方法可以做到你想要什么:

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

随着Redis的2.6,你也可以使用Lua脚本,但这不是真的在这里需要。

顺便说一句,您所描述的数据结构可以通过使用散列得到改善。 相反,存储单独的密钥的用户数据,你可以在他们的哈希对象组。

使用sort命令

您可以使用Redis的sort命令在一个往返检索数据。

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"

这里的成本是还有两个往返。 这个工作,如果你能保证键检索的数量是有限的。 如果不是这样,流水线是一个更好的解决方案。



Answer 2:

您可以使用Redis的EVAL命令发送它的Lua脚本运行的循环‘服务器端’,返回的结果块。



文章来源: Getting multiple key values from Redis