express 如何使用cluster 运行?
发布于 10 年前 作者 youqingkui 11419 次浏览 最后一次编辑是 8 年前

现在express 是使用./bin/www 来运行。看了下里面的代码是这样

#!/usr/bin/env node
var debug = require('debug')('seller');
var app = require('../app');

app.set('port', process.env.PORT || 3001);

var server = app.listen(app.get('port'), function() {
  debug('Express server listening on port ' + server.address().port);
});

我要使用cluster是否改这里的代码?可否给个小例,谢谢!

20 回复

var debug = require(‘debug’)(‘my-application’); var app = require(’…/app’); var cluster = require(‘cluster’) var numCPUs = require(‘os’).cpus().length;

if(cluster.isMaster){
	console.log("宿主启动...");

	for (var i = 0; i < numCPUs; i++) {
		cluster.fork();
	}
	cluster.on('listening',function(worker,address){
		console.log('核心'+i+' pid:'+ worker.process.pid);
	});
	cluster.on('exit', function(worker, code, signal) {
		console.log('核心'+i+' pid:'+ worker.process.pid+' 重启')
		setTimeout(function() {cluster.fork();},2000);
	});
}else{
	app.set('port',88);
	var server = app.listen(app.get('port'),function() {
	});
}

//已经按照你的配置改动了下。这个是会自动延迟重启线程的代码。也就是所谓的NODE不会挂。但是错误还是要排查。

@MiguelValentine 嗯,非常感谢!

@MiguelValentine 发现个问题要是有个进程重启了,重启会再挂个进程,启动两个进程。这是什么原因啊? 核心4 pid:805 重启 核心4 pid:810 核心4 pid:811

@shaun 感觉这是个简版的,谢谢!

@youqingkui 我这边的环境不会_(:з」∠)_。

@MiguelValentine 我的是mac ox,与Ubuntu 12.04.4 LTS 都是这样子。

@youqingkui 你确定只挂了一个核心它重启两个?因为你核心数就只有那么多啊。不可能多FORK出来其他的。

@shaun 咳。。。还是建议-- > 这样的代码少写,没有太多语义化

看了lz的需求可以啊,都集群了,考虑多线程了,真棒~

@MiguelValentine 嗯,他是挂了一个,然后重启的时候会有显示新开了两个进程。但是我看进程数没有变,那他是cluster.fork() 的时候挂了另外一个。 核心4 pid:805 重启 核心4 pid:810 核心4 pid:811

1.png 2.png 为什么我只开启2个,而线程中有3个?

@MiguelValentine 为什么我只开启2个,而线程中有3个?一个是主线程,另外2个是工作线程吗?

利用pm2吧,不要自己开了

@DoubleSpout 使用pm2或者使用cluster 模块来开启多线程 与使用nignx 有重复吗?

@shantouyyt 是啊,一个核心即当主程,又分配任务

lz的主程主要是用来处理什么逻辑业务?

用 passenger 管理进程。

收藏 自豪地采用 CNodeJS ionic

回到顶部