【问题标题】:How do I get SocketCluster to restart on file change?如何让 SocketCluster 在文件更改时重新启动?
【发布时间】:2015-10-23 21:02:16
【问题描述】:

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

【问题讨论】:

  • 如果您使用集群,PM2 将允许您在文件更改时重新启动而无需停机。
  • ECONNREFUSED 是因为您的子进程没有被正确杀死,PM2 可以帮助避免的其他事情。
  • @dandavis 特别适用于 SocketCluster 吗?它有自己的集群机制。
  • 不确定,但是 PM2 可以处理节点以外的东西,所以如果我不得不猜测的话,“可能”......

标签: javascript node.js socketcluster


【解决方案1】:

nodemonSIGUSR2 信号发送到主(Master)进程。 SocketCluster(正确)将此解释为重新启动工作人员的请求。不幸的是,有一个open issue 没有正确关闭,错误到处都是。

有两种选择:

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

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

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

forever -w --killSignal=SIGTERM server.js

【讨论】:

  • 嗨 .. 究竟会在哪里实现呢?这是我需要在 sc 代码本身中指定的补丁吗?我对使用的 house 变量感到困惑
【解决方案2】:

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

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

【讨论】:

    猜你喜欢
    • 2012-06-15
    • 2010-10-27
    • 2012-06-25
    • 1970-01-01
    • 1970-01-01
    • 2016-03-12
    • 1970-01-01
    • 2010-11-23
    • 1970-01-01
    相关资源
    最近更新 更多