如何让 SocketCluster 在文件更改时重新启动?
How do I get SocketCluster to restart on file change?
我是 运行 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 以加载新的更改?
nodemon
发送SIGUSR2
信号给主(Master)进程。 SocketCluster(正确地)将此解释为重新启动工作人员的请求。不幸的是,有一个 open issue 没有正确关闭并且错误到处都是。
有两种选择:
您可以添加链接问题中的代码:
house.addShutdownHandler(function(ctx, next){
socketCluster.killWorkers();
socketCluster.killBrokers();
next();
});
或使用forever
发送"restart everything"信号:
forever -w --killSignal=SIGTERM server.js
在 SC 5.0.23 或更高版本中对 nodemon 进行了改进。
确保在代码(server.js 文件)中实例化 SocketCluster 时传递 killMasterOnSignal: true
- 此设置是 nodemon 工作所必需的。
我是 运行 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 以加载新的更改?
nodemon
发送SIGUSR2
信号给主(Master)进程。 SocketCluster(正确地)将此解释为重新启动工作人员的请求。不幸的是,有一个 open issue 没有正确关闭并且错误到处都是。
有两种选择:
您可以添加链接问题中的代码:
house.addShutdownHandler(function(ctx, next){
socketCluster.killWorkers();
socketCluster.killBrokers();
next();
});
或使用forever
发送"restart everything"信号:
forever -w --killSignal=SIGTERM server.js
在 SC 5.0.23 或更高版本中对 nodemon 进行了改进。
确保在代码(server.js 文件)中实例化 SocketCluster 时传递 killMasterOnSignal: true
- 此设置是 nodemon 工作所必需的。