javascript - 关于nodejs中进程间的负载均衡
高洛峰
高洛峰 2017-04-10 17:40:12
[JavaScript讨论组]
//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发送过去了以让子进程监听端口。。。所以现在有些懵逼不知道怎么往下写了。。。
希望大神们帮帮忙。。。

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(0)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号