Node学习记录之cluster模块

在如今机器的CPU都是多核的背景下,Node的单线程设计已经没法更充分的"压榨"机器性能了。所以从v0.8开始,Node新增了一个内置模块——“cluster”,故名思议,它可以通过一个父进程管理一坨子进程的方式来实现集群的功能。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
var cluster = require( 'cluster' );
var http = require( 'http' );
var numCPUs = require( 'os' ).cpus().length; // 获取CPU的个数
if (cluster.isMaster) {
for ( var i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on( 'exit' , function (worker, code, signal) {
console.log( 'worker ' + worker.process.pid + ' died' );
});
} else {
http.createServer( function (req, res) {
res.writeHead(200);
res.end( "hello world\n" );
}).listen(8000);
}

通过isMaster属性,判断是否Master进程,是则fork子进程,否则启动一个server。每个HTTP server都能监听到同一个端口。但是在实际项目中,我们的启动代码一般都已经封装在了app.js中,要把整块启动逻辑嵌在上面的if else中实在不优雅。 所以,我们可以这样:


1
2
3
4
5
6
7
8
9
10
11
12
var cluster = require( 'cluster' );
var numCPUs = require( 'os' ).cpus().length;
if (cluster.isMaster) {
for ( var i = 0; i < numCPUs; i++) {
cluster.fork();
}
// 其它代码
} else {
require( "./app.js" );
}

简单之处就在于原本的应用逻辑根本不需要知道自己是在集群还是单边。(当然,如果应用在内存中维护了某些状态,比如session,就需要运用某些机制来共享了,这里不详说)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值