首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使SocketCluster在文件更改时重新启动?

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

Stack Overflow用户
提问于 2015-10-23 21:02:16
回答 2查看 395关注 0票数 1

我正在运行http://socketcluster.io/,我想重新启动我的工作人员,因为他们从不更改文件。但是,当nodemon server.js试图使用以下不断重复的墙重新启动时,它就会失败:

代码语言:javascript
复制
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以加载新的更改?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-10-23 21:02:16

nodemon向主进程(主进程)发送SIGUSR2信号。SocketCluster (正确)将此解释为重新启动工作人员的请求。不幸的是,有一个公开发行,其中的事情没有正确关闭和错误到处飞。

有两种选择:

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

代码语言:javascript
复制
house.addShutdownHandler(function(ctx, next){
    socketCluster.killWorkers();
    socketCluster.killBrokers();
    next();
});

或者使用forever发送“重新启动一切”信号:

代码语言:javascript
复制
forever -w --killSignal=SIGTERM server.js
票数 2
EN

Stack Overflow用户

发布于 2016-11-16 16:38:32

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

确保在代码中实例化killMasterOnSignal: true时传递SocketCluster (server.js文件)--这个设置对于nodemon的工作是必要的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33311344

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档