我是socket.io和Node JS的新手,我试图用大量的同步套接字连接(10,000+)构建一个可伸缩的应用程序。socket.io的可伸缩体系结构
目前,我开始创建一个模型,在该模型中我的服务器创建子进程,并且每个子进程使用附加的sicket.io实例来侦听特定的端口。一旦客户端连接,他将被重定向到特定的端口。
最大的问题是:几个端口上有多个socket.io实例会增加可能的连接数量吗?
这里是我的代码,以防万一:
服务器
var server = http.createServer(app);
server.childList = [];
for (var i = 0; i < app.portList.length; i++) {
server.childList[i] = require('child_process').fork('child.js');
}
server.listen(3443,() => {
for (var i = 0; i < app.portList.length; i++) {
server.childList[i].send({ message: 'createServer', port: app.portList[i] });;
}
});
child.js:
var app = require('./app');
var http = require('http');
var socket_io = require("socket.io");
process.on('message', (m) => {
if (m.message === 'createServer') {
var childServ = http.createServer(app);
childServ.listen(m.port,() => {
console.log("childServ listening on port "+m.port);
});
var io = socket_io();
io.attach(childServ);
io.sockets.on('connection', function (socket) {
console.log("A client just connected to my socket_io server on port "+m.port);
});
}
});
随意释放海妖,如果我做了一件可怕的存在