2

我正在使用 Node JS 服务器 (0.10.30) 及其集群功能。每次工作人员终止时,我都会捕获“退出”事件并重新启动新工作人员。我还想记录(在主集群上)工作人员被终止的原因,例如异常或致命错误。

怎么做?

我的 app.js 文件看起来像这样:

var cluster = require('cluster');
var numCPUs = 2;

if (cluster.isMaster) {
  for (var i = 0; i < numCPUs; i++) {
    cluster.fork();
  } 
  
  cluster.on('exit', function(worker, code, signal) {
	console.log('worker %d died. Starting a new worker:', worker.id);
	cluster.fork();
});

} else {
  var domain = require('domain');
  var d = domain.create();
  d.on('error', function(er) {
    console.error('error: ', er.stack);
    // I never get the memory fatal error here 
  });

  d.run(function() {
    // The memory runs out in an async call
  });
}

谢谢, 埃雷兹

4

1 回答 1

0

好吧,您可以使用该功能将消息从工作人员发送到主设备send(),如文档中所述:

http://nodejs.org/api/cluster.html#cluster_worker_send_message_sendhandle

但是 Node 的一般原则是按预期使用 stdout 和 stderr,所以console.error('whatever you need to say');如果是我,我可能会这样做。

====根据评论更新====

在大多数情况下,如果进程崩溃是因为未捕获的异常。因此,如果您可以预料到这些异常,请在适当的对象上监听它们。要捕获您未预测到的错误,请侦听进程上的uncaughtException事件,并在该处理程序中发送您的消息或控制台

于 2014-11-06T16:25:27.240 回答