node.js - 为棋盘游戏 session 数据保留数据时,redisJSON 是否比普通 redis 更好?

标签 node.js json database express redis

刚刚用 ioredis 为我的后端加载了一个 redis 服务器。
我正在学习,如果我想以 json 规范存储数据,我必须改用 redisJSON 模块。由于哈希只是字符串类型的并且它们是扁平的。但是,如果我每个用户实例只存储一个对象,包含少于 10 个类型为字符串/数字或数组的字段.. 不使用 redisJSON 是否更好?一方面,redisJSON 可以让我一次查询一个对象。另一方面,我可以使用一致的命名约定在这些集合/散列之间存储多个数据类型和查询。
有谁知道这两种方法有什么更好的用法或陷阱?
后端为多人棋盘游戏提供 websocket。

最佳答案

答案是视情况而定,需要为每个项目做出一些权衡

  • 性能:RedisJSON 使用树结构来存储文档中的所有元素。
  • 与字符串相比:优点是更新文档的子元素将比操作包含序列化 JSON 对象的字符串更快。但是与字符串相比,检索(重组)和编写整个文档的成本会更高。 Read more here
  • 与 Hash 比较:在操作平面文档(1 级深度)时,RedisJSON 和 HSET 性能相当。

  • 可维护性:在Redis中使用几种原生数据类型来表示你的对象确实可以执行,但是代码维护起来会比较复杂。当文档的结构发生变化时,可能会有额外的迁移/重构工作。
  • 查询:RediSearch has support for indexing and querying the content RedisJSON documents 。当然,如果您的用例需要辅助索引和查询文档而不是使用它们的键,那么这是当然的。您仍然可以使用 Redis 数据结构构建自己的二级索引,但这也是可维护性的权衡

  • 免责声明:我在 Redis 工作,是 RediSearch 和 RedisJSON 的创建者和维护者

    关于node.js - 为棋盘游戏 session 数据保留数据时,redisJSON 是否比普通 redis 更好?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67929784/

    相关文章:

    javascript - typescript 对象序列化?

    database - 哪个更好 ?具有更快数据访问的冗余,或者没有冗余和更慢的数据访问

    mysql - 优化高插入/选择/删除表

    node.js - 如何防止 mongodb 支持的分布式 Nodejs Web 服务器架构中的竞争条件

    model-view-controller - Node.js MVC 框架

    javascript - 按国家数量对各大洲进行排序

    php - 为什么 JSON 只为我的查询返回 1 个图像输出?

    javascript - 如何在 NodeJs 中使用请求进行多个 API 调用?

    javascript - Grunt 登录已注册的任务?

    Asp.net:ScriptManager 不工作