如何让SocketCluster在文件更改时重新启动?

时间:2015-10-23 21:02:17

标签: javascript node.js socketcluster

我正在运行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以加载新的更改?

2 个答案:

答案 0 :(得分:2)

nodemonSIGUSR2信号发送到主(主)进程。 SocketCluster(正确地)将此解释为重启工作者的请求。不幸的是,有一个open issue,事情没有正确关闭,错误四处传播。

有两种选择:

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

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

或使用forever发送“重启所有内容”信号:

forever -w --killSignal=SIGTERM server.js

答案 1 :(得分:0)

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

确保在代码中实例化SocketCluster时传递#!/bin/bash # Get index of last frame in TIFF image last=$(convert stack1.tif -print "%[fx:n-1]" null:) # Combine all frames for i in `seq 0 $last`; do convert stack1.tif[$i] stack2.tif[$i] -combine miff:- done | convert miff:- -compress lzw result.tif (server.js文件) - 此设置是nodemon工作所必需的。