我刚开始接触 socket.io 和 Node.js,并尝试构建一个具有大量并发 socket 连接(10,000+)的可扩展应用程序。
目前,我基于一个模型开始了工作,在该模型中我的服务器创建子进程,每个子进程都使用附加了 socket.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);
});
}
});
如果我做了什么可怕的事,请随意释放海怪