Socket.io 命名空间限制以及如何扩展它

Socket.io namespace limit and how to scale it

我的 socket.io 应用程序必须处理大量命名空间。我想知道 socket.io 实例可以处理的名称空间数量限制是多少,如果我创建 10k 名称空间会有什么问题。我如何扩展以在多个 socket.io 实例之间进行类似 scharding 的操作(例如,每个实例处理 1k 命名空间)。实际上,我可以扩展以支持多个用户,但我的所有实例都必须处理所有命名空间。

更新 1:

我要解决的问题如下,我有一个多人纸牌游戏(如扑克牌),每个房间都有 4 名玩家玩游戏,由 socketio 命名空间建模。因为我期望有成千上万的并发玩家,所以我的 socketio 实例应该处理这个数量的命名空间。 我已经实施了 Socket.io website 中解释的可伸缩性解决方案。当我横向扩展时,这个节点片段我 运行 在新实例中,因此它可以处理之前创建的所有命名空间。

rooms.forEach(function(room){
    var socketRoom = io.of('/room/' + room.id)
    .on('connection', function(mySocket){
        return handleTableSocket(mySocket, socketRoom, room);
    });
});

那么用 socketio 命名空间为每个游戏房间建模是个好主意吗?如果命名空间的数量增加怎么办?

干杯

socket.io 中的命名空间只是一个 Javascript 对象,并且有一个主对象维护所有现有命名空间对象的索引。除了 Javascript 对象及其在 ndoe.js 进程中的实例数据消耗的内存量之外,您可以拥有多少没有固有的限制。创建所需数量的命名空间并测量它们的内存消耗的快速测试似乎是一个很好的第一步。

您可以通过部署多个 node.js 进程在 node.js 中扩展 socket.io。 socket.io 站点 (Using multiple nodes) 上讨论了一般概念。该通用方案通过使用 redis 来管理要在多个实例之间共享的数据。此方案不会在特定实例上为特定用户创建首选项。如果你想做类似的事情,以便在每个实例中只有一些命名空间,那么这可能可以通过自定义编码来完成,但你必须解释更多关于你试图解决的问题我们对如何处理它有很多想法。

同样,如果您分享了您试图解决的实际问题(而不仅仅是您尝试的解决方案),我们可能会提出一个比 10k 实际名称空间更有效的解决方案,方法是使用您自己的数据结构比通用命名空间更针对您的特定问题。