gpt4 book ai didi

javascript - 管理 Node Websockets topic-subscriber Map 的最佳方式是什么?

转载 作者:可可西里 更新时间:2023-11-01 11:20:28 25 4
gpt4 key购买 nike

在服务于 websockets 的 Node 应用程序中,用户可以订阅多个已发布的主题并实时获取主题的新更新,存储主题-订阅者映射的最佳方式是什么?

实时主题:主题 1、主题 2、主题 3、主题 4

User1 订阅了主题 1、主题 2、主题 4。User2 订阅了 Topic2,Topic4。

所以应该有一个 map 对象如下

Topic1=>[User1]
Topic2=>[User1,User2]
Topic4=>[User1,User2]

因此,当 Topic1 有更新时,应用程序应将更新传递给 User1 的 websocket。

问题:将主题-订阅者映射保留为应用程序变量(javascript 对象)是否足够好?还是使用 REDIS 来管理它更好?

我还想将信息存储在此 map 中,以分析趋势,例如按地理划分的主题兴趣随时间的变化。因此,该数据应在后台复制到原始数据库中。

我认为我不应该在每次有主题更新时都查询数据库来查找当前订阅者。

正如我设法找到的那样,REDIS 是一个内存数据存储。 javascript 应用程序变量也将存在于 RAM 中。

最好的方法是什么?

需要以最快的速度更新订阅者的性能。

最佳答案

我个人认为在 Redis 中执行此操作更好,但这只是因为随着应用程序的扩展,您迟早会需要多个 Node 。当你这样做的时候,你就离开了 NodeJS 领域,并试图找到一些方法来跨集群协调这项工作。 Redis 非常适合这项任务。

也就是说,也许你应该看看 ActionHero框架。它的聊天模块正是您想要做的。使用很少的代码,您可以让 WebSocket 客户端连接到集群中的一个或多个 Node (由 Redis 协调)并加入零个或多个聊天室,然后接收发送到这些房间的消息。它可以为您节省一些时间。

关于javascript - 管理 Node Websockets topic-subscriber Map 的最佳方式是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37418015/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com