express 如何使用cluster 运行?
发布于 6个月前 作者 youqingkui 576 次浏览

现在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是否改这里的代码?可否给个小例,谢谢!

11 回复

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 发现个问题要是有个进程重启了,重启会再挂个进程,启动两个进程。这是什么原因啊? 核心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

回到顶部