express 如何使用cluster 运行?
发布于 11 年前 作者 youqingkui 12139 次预览 最后一次回复是 10 年前 来自
现在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;
//已经按照你的配置改动了下。这个是会自动延迟重启线程的代码。也就是所谓的NODE不会挂。但是错误还是要排查。
@MiguelValentine 嗯,非常感谢!
https://gist.github.com/shaunlee/40c408eb4aea862beb0c
@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
收藏了
@MiguelValentine 为什么我只开启2个,而线程中有3个?一个是主线程,另外2个是工作线程吗?
利用pm2吧,不要自己开了
@DoubleSpout 使用pm2或者使用cluster 模块来开启多线程 与使用nignx 有重复吗?
@shantouyyt 是啊,一个核心即当主程,又分配任务
lz的主程主要是用来处理什么逻辑业务?
用 passenger 管理进程。
收藏 自豪地采用 CNodeJS ionic