express cluster 多进程

本文介绍了如何使用Node.js和cluster模块创建一个并发服务器,利用多进程提高服务器性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

var app = require('../app');

var debug = require('debug')('hello:server');    //项目名为hello 其他的改hello

var cluster = require('cluster');

var numCPUs = require('os').cpus().length;


/**

 * Get port from environment and store in Express.

 */


if(cluster.isMaster){            //判断进程是否工作

    console.log('[master] ' + "start master...");    


    for (var i = 0; i < numCPUs; i++) {        //根据CPU通道  开启进程

         cluster.fork();

    }


    cluster.on('listening', function (worker, address) {        //为cluster绑定listening事件

        console.log('[master] ' + 'listening: worker' + worker.id + ',pid:' + worker.process.pid + ', Address:' + address.address + ":" + address.port);

    });

}else{                                                                                //进程已启动   开启http服务

console.log('[worker] ' + "start worker ..." + cluster.worker.id);    

var port = normalizePort(process.env.PORT || '3000');

app.set('port', port);


/**

* Create HTTP server.

*/


var server = http.createServer(app);


/**

* Listen on provided port, on all network interfaces.

*/


server.listen(port);

server.on('error', onError);

server.on('listening', onListening);


}

转载于:https://my.oschina.net/wisdomofgod/blog/403530

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值