data-structures - 我将如何在 Redis 中构建这些数据?

标签 data-structures redis

这是我希望我的数据结构看起来像的示例:

[games]:
   [game_1]:
       players: 10
       maxPlayers: 24
       state: "PLAYING"
       currentMap: "Example Map"
   [game_2]:
       players: 0
       maxPlayers: 24
       state: "LOBBY"
       currentMap: "None"

我正在使用 Redis (Jedis) 的 Java 实现来缓存来自已注册游戏服务器的数据。代理服务器将所有已注册的游戏服务器连接在一起,但是,代理无法中继此类数据。因此,我采用了 Redis 方法并将其集成到所有游戏服务器共享的核心插件中。 lobby 服务器将能够从 Redis 访问数据,以向玩家显示实时游戏统计信息。我将如何构建它?我是 Redis 的新手,数小时的搜索无济于事。请用简单的术语解释一下。 我希望能够进行方法调用以获取特定游戏的数据并遍历 Redis 数据库中的所有缓存游戏。 (例如游戏:{"game_1", "game_2"})

最佳答案

解决此问题的一种方法是:

  1. 将您的游戏存储在哈希中 - 每个游戏一个哈希。哈希的键名应该是您游戏的标识符,其中的字段->值应该对应于您游戏的属性。在 Redis 行话中,应该这样完成:

    HMSET game_1 players 10 maxPlayers 24 state PLAYING currentMap "Example Map"

  2. 游戏更新只需调用 HSET game_1 players 11触摸特定属性。

  3. 您可以使用HGET 读取特定游戏的一个、多个属性或所有属性。 , HMGETHGETALL分别。

  4. 可以通过以下两种方式之一获取所有游戏:

    一个。使用 SCAN检索数据库中的键名,并在每个键名上调用第 3 步中的 API。优点:无需额外维护,缺点:可能会更慢。

    维护一个由您的游戏标识符(键名)组成的 Set - 获取所有游戏,获取该 Set 的内容,并为其每个成员使用第 3 步中的 API。优点:获取所有游戏的性能更好,缺点:需要维护另一个数据结构(集合)。

关于data-structures - 我将如何在 Redis 中构建这些数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34059464/

相关文章:

c# - 如何向域对象的构造函数提供 RequestContext 数据?

java - 为什么不能设置 ConcurrentSkipListMap 的初始容量?

sorting - 获取redis中key的权重

linux - 为 Redis 3.2.6 调整 Linux 内核堆栈

c# - StackExchange.Redis 与 Azure Redis 速度慢得无法使用或引发超时错误

java - 服务器架构 - Redis 与 Socket 服务器

algorithm - 如何判断一个图是否是二分图?

java - 高效的自然语言数据结构、持久化和查询

Redis:为什么移动到另一个主机

c - C 中用位表示一组整数