node.js - 如何获取 Strongloop 集群内的工作进程/进程 ID 列表?

标签 node.js strongloop

看起来 Strongloop 集群中的每个进程都被视为一个工作进程,因此,如果您使用 Node 调度程序之类的工具来调度作业,并且您有多个工作进程,则作业会被执行多次。

理想情况下我能够做这样的事情:

var cluster = require('cluster');
if (cluster.isMaster) {
 // execute code
}

由于这似乎不可能,我想知道是否有一种方法可以从 Node 应用程序内部获取所有工作人员或进程 ID 的列表,以便我可以用一个工作人员做同样的事情?这需要是动态的,因为 cluster.worker.id 似乎不是执行此操作的可靠方法,因为工作线程 ID 是不可预测的。

想法?

最佳答案

  1. “strongloop cluster”不是一个东西,它是一个 Node 集群:https://nodejs.org/dist/latest-v6.x/docs/api/cluster.html

  2. 不存在这样的 API,它对您没有帮助,您需要实现某种共识算法来选择一组(动态的,工作人员可能会死亡并被替换/重新启动)工作人员中的一个作为“单例”

  3. 将您的系统组成微服务,如果您需要单例任务运行程序,请将其设为服务,并以集群大小 1 运行它。

  4. 这并不是真正的集群问题,而是无法扩展的问题,不是吗?集群进行内部扩展,您可以将调度服务限制为一个……但是当您跨多个虚拟机(多个 Heroku dyno、多个 docker 容器等)进行扩展时,这仍然会崩溃……这将是定时 Node 调度作业的来源?

关于node.js - 如何获取 Strongloop 集群内的工作进程/进程 ID 列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38315338/

相关文章:

Strongloop:currentContext 在中间件中不可用?

Node.js AWS SDK 请求未接收响应数据..在一个文件中,而不是在另一个文件中

node.js - lb-ng 环回命令从异步模块返回 "Cannot read property ' apply' of undefined"

javascript - 对 mongoose 和 es6 的 promise 没有按预期工作

mysql - 将 npm api 连接到 MySQL 时 docker ECONNREFUSED

mysql - Strongloop mysql 连接器 ER_NO_DB_ERROR : No database selected

node.js - StrongLoop 的 LoopBack.io : How to turn on HTTP access log?

node.js - 环回 : logging queries executed by datasource

node.js - 根据 mongodb 中第一个表的结果从第二个表加载数据

sql - 如何在 knex.js 中将连接表中的数据嵌套在一个(或多个)对多关系中?