看起来 Strongloop 集群中的每个进程都被视为一个工作进程,因此,如果您使用 Node 调度程序之类的工具来调度作业,并且您有多个工作进程,则作业会被执行多次。
理想情况下我能够做这样的事情:
var cluster = require('cluster');
if (cluster.isMaster) {
// execute code
}
由于这似乎不可能,我想知道是否有一种方法可以从 Node 应用程序内部获取所有工作人员或进程 ID 的列表,以便我可以用一个工作人员做同样的事情?这需要是动态的,因为 cluster.worker.id
似乎不是执行此操作的可靠方法,因为工作线程 ID 是不可预测的。
想法?
最佳答案
“strongloop cluster”不是一个东西,它是一个 Node 集群:https://nodejs.org/dist/latest-v6.x/docs/api/cluster.html
不存在这样的 API,它对您没有帮助,您需要实现某种共识算法来选择一组(动态的,工作人员可能会死亡并被替换/重新启动)工作人员中的一个作为“单例”
将您的系统组成微服务,如果您需要单例任务运行程序,请将其设为服务,并以集群大小 1 运行它。
这并不是真正的集群问题,而是无法扩展的问题,不是吗?集群进行内部扩展,您可以将调度服务限制为一个……但是当您跨多个虚拟机(多个 Heroku dyno、多个 docker 容器等)进行扩展时,这仍然会崩溃……这将是定时 Node 调度作业的来源?
关于node.js - 如何获取 Strongloop 集群内的工作进程/进程 ID 列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38315338/