gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-03 22:12:21 24 4
gpt4 key购买 nike

看起来 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com