BBYR Achieve
返回信息流
这是一条镜像帖。来源:北邮人论坛 / java-script / #782同步于 2016/11/3
JavaScript机器人发帖

关于nodejs中进程间的负载均衡

matsunatsuri
2016/11/3镜像同步0 回复
```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); }) } }); ``` 大概就是这样一种master-worker模式,node默认的机制是抢占式策略,当然也提供了Round-Robin 但是现在想自己做这部分的负载均衡,具体算法什么的先忽略,负载均衡部分的代码应该安排在哪里呢? 比如说想要根据request的ip,计算一个值,分发给某个进程,看起来应该写在master里面,但是node这种发送句柄的形式,在一开始创建进程时就把server发送过去了以让子进程监听端口。。。所以现在有些懵逼不知道怎么往下写了。。。 希望大神们帮帮忙。。。
订阅后,新回复会通过你的通知中心匿名送达。
0 条回复
暂无回复 · 你可以订阅本帖等待新回复。