我参与了聊天的开发项目,我们正在使用node.js,socket.io(rooms)和mongodb。我们正处于性能测试阶段,如果系统需要负载平衡,我们非常关注。
如果我们的项目需要,我们如何发展? J'对NGINX的研究看起来很酷,但我们怀疑是否解决了我们的问题,因为系统将如何进行聊天,我们担心服务器不能正确地相互交谈......
如果我们需要负载平衡,我们该去哪里?
答案 0 :(得分:10)
为了确保我们可以扩展到多个节点但保持不同客户端和不同服务器之间的互连,我使用redis。实际上使用和设置非常简单。
这样做会在您的服务器之间创建一个pub / sub系统,以跟踪您的不同套接字客户端。
var io = require('socket.io')(3000),
redis = require('redis'),
redisAdapter = require('socket.io-redis'),
port = 6379,
host = '127.0.0.1',
pub = redis.createClient(port, host),
sub = redis.createClient(port, host, {detect_buffers: true}),
server = http(),
socketServer = io(server, {adapter: redisAdapter({pubClient: pub, subClient: sub})});
在此处阅读更多内容:socket.io-redis
就处理不同的节点服务器而言,有不同的方法。
其中......
答案 1 :(得分:3)
查看NPM包mong.socket.io。它能够将socket.io数据保存到mongoDB,如下所示;
{
"_id" : ObjectId("54b901332e2f73f5594c6267"),
"event" : "join",
"message" : {
"name" : "join",
"nodeId" : 426506139219,
"args" : "[\"URAiA6mO6VbCwquWKH0U\",\"/54b6821asdf66asdasd2f0f9cd2997413780273376\"]"
}}
或者你可以使用那里提到的redis适配器;
Socket.IO Using multiple nodes
然后只使用NGINX反向代理,所有节点进程都应该相互共享Socket.IO事件。