关于nodejs中进程间的负载均衡
//master.js
var server = require('net').createServer();
server.listen(port);
var createWorker = function(){
var worker = fork(__dirname + '/worker.js');
worker.send('server',server);
}
for(var i = 0; i < cpus.length; i++){
createWorker();
}
//worker.js
var http = require('http');
var server = http.createServer(function(req,res){
res.writeHead(200,{'Content-Type':'text/plain'});
res.end('handled by child,pid is ' + process.pid + '\n');
});
process.on('message',function(m,tcp){
if(m === 'server'){
worker = tcp;
worker.on('connection',function(socket){
server.emit('connection',socket);
})
}
});
最近在学习node中的多进程。
大概就是这样一种master-worker模式,node默认的机制是抢占式策略,当然也提供了Round-Robin
但是现在想自己做这部分的负载均衡,具体算法什么的先忽略,负载均衡部分的代码应该安排在哪里呢?
比如说想要根据request的ip,计算一个值,分发给某个进程,看起来应该写在master里面,但是node这种发送句柄的形式,在一开始创建进程时就把server发送过去了以让子进程监听端口。。。所以现在有些懵逼不知道怎么往下写了。。。
希望大神们帮帮忙。。。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论