【发布时间】:2013-12-07 11:26:22
【问题描述】:
使用 socket.io redisstore 适配器/存储 (?),是否可以“查看”所有客户端并“选择”甚至是未直接连接到您的 socket.io 服务器的客户端?还是仅限于 socket.io 的“房间”功能?
举一个实际的例子,同一个聊天室中的两个用户连接到两个不同的 socket.io 节点,redisstore 适配器/存储是否可以在不对代码进行大量更改的情况下从一个用户耳语到另一个用户您已经有一个有效的单进程/服务器实现了吗?
我问的原因是我目前还没有在我的项目的开发阶段过度关注缩放(我也没有时间深入研究 node.js 缩放背后的概念,这看起来与我已经习惯了(现在是第一个成熟的 node.js 项目)),但是我不想构建一个无法扩展的基础设施。
【问题讨论】:
-
如果您使用的是节点集群,您可能还会使用 clusterhub 之类的东西,并且可能使用socket.io clusterhub 来跨集群共享数据,然后这不再是一个真正的问题,但作为据我所知,您仍然必须使用房间来识别用户等。
标签: javascript node.js redis socket.io node-redis