Benchmarkt socket.io
Eu quero benchmark meu servidor socket.io. Quero testar quantas conexões e mensagens paralelas o servidor pode manipular.
Mas o meu servidor socket.io travou depois de alguns minutos quando iniciei o benchmark com cerca de 200 websockets.
Eu tentei usar o módulo de cluster de node.js para compartilhar o processo com os núcleos. Quando uso o módulo de cluster, algumas conexões são desconectadas após algum tempo.
O servidor que eu uso para o teste é um servidor virtual na nuvem amazon com essas propriedades:
7 GB de memória20 Unidades computacionais EC2 (8 núcleos virtuais com 2,5 Unidades computacionais EC2 cada)1690 GB de armazenamento de instânciaPlataforma de 64 bitsDesempenho de E / S: altoNome da API: c1.xlargeAqui está o código do benchmark-client:
var fs = require('fs');
var io = require("socket.io-client");
var host = "http://localhost:3000";
var timeLog = fs.createWriteStream(__dirname+'/public/time.log',{flags:'a',mode:0666, encoding:'encoding'});
var count = 200;
var sockets = [];
var total = 0;
var countTime = 0;
var echo = exports;
echo.start = function() {
fs.writeFile('public/time.log',"",function(err){
if(err) throw err;
});
for(var i=0;i<count;i++){
var socket = io.connect(host,{"force new connection":true});
sockets.push(socket);
//console.log(i);
socket.on("message",function(message){
countTime++;
time = new Date().getTime()-message;
total+=time;
timeLog.write(time+"\n");
socket.send(new Date().getTime());
});
socket.on("disconnect",function(){
console.log("disconnect");
});
}
parallelSockets();
var j = 0;
}
function parallelSockets(){
for(var i = 0 ;i<count;i++){
sockets[i].send(new Date().getTime());
}
}
E aqui o código do socket.io-server:
socket.on('message',function(message){
start = new Date().getTime();
socket.send(message);
end = new Date().getTime() - start;
logfile.write(end+"\n");
});
Existe algum mecanismo de segurança no socket.io que bloqueia tantas mensagens paralelas e conexões formando um cliente?
Alguém pode me ajudar?