1

我正在运行http://socketcluster.io/并且我想在文件更改时重新启动我的工作人员。但是,nodemon server.js一旦尝试以无休止重复的墙重新启动,就会失败:

1445633138359 - Origin: Worker (PID 44372)
    [Error] Error: connect ECONNREFUSED /var/folders/fj/yzfd3_tn7xd0smz7j6s093mh0000gn/T/socketcluster/6879fe94-ed92-4188-b1d7-cb187a5ade4e_b68fcded6c/b0
    at Object.exports._errnoException (util.js:874:11)
    at exports._exceptionWithHostPort (util.js:897:20)
    at PipeConnectWrap.afterConnect [as oncomplete] (net.js:1063:14)
1445633138362 - Worker 0 exited - Exit code: 0

如何安全地重新启动 SocketCluster 以加载新更改?

4

2 回答 2

2

nodemonSIGUSR2信号发送到主(主)进程。SocketCluster(正确)将此解释为重新启动工作人员的请求。不幸的是,有一个未解决的问题,即事情没有正确关闭并且错误四处飞散。

有两种选择:

您可以添加链接问题中的代码:

house.addShutdownHandler(function(ctx, next){
    socketCluster.killWorkers();
    socketCluster.killBrokers();
    next();
});

或用于forever发送“重启一切”信号:

forever -w --killSignal=SIGTERM server.js
于 2015-10-23T21:02:16.597 回答
0

SC 版本 5.0.23 或更高版本中对 nodemon 进行了改进。

确保killMasterOnSignal: true在您的代码(server.js 文件)中实例化 SocketCluster 时通过 - 此设置是 nodemon 工作所必需的。

于 2016-11-16T16:38:32.780 回答