搜索
首页web前端js教程了解 Node.js 集群:核心概念

Understanding Node.js Cluster: The Core Concepts

前言

如果您使用 PM2 来管理 Node.js 进程,您可能已经注意到它支持集群模式。这种模式允许 Node.js 创建多个进程。当您将集群模式下的实例数量设置为 max 时,PM2 会自动创建与服务器上可用 CPU 核心相对应的 Node 进程数。

PM2 通过利用 Node.js 的 Cluster 模块来实现这一点。该模块解决了 Node.js 的单线程特性,该特性传统上限制了其利用多个 CPU 核心的能力。但是 Cluster 模块内部是如何工作的呢?进程之间如何通信?多个进程如何监听同一个端口? Node.js 如何将请求分发到这些进程?如果您对这些问题感到好奇,请继续阅读。

核心原则

Node.js 工作进程是使用 child_process.fork() 方法创建的。这意味着有一个父进程和多个子进程。代码通常如下所示:

const cluster = require('cluster');
const os = require('os');

if (cluster.isMaster) {
  for (let i = 0, n = os.cpus().length; i 



<p>如果您研究过操作系统,您可能熟悉 fork() 系统调用。调用进程是父进程,而新创建的进程是子进程。这些子进程与父进程共享相同的数据段和堆栈,但它们的物理内存空间不一定共享。在 Node.js 集群中,<strong>master</strong> 进程侦听端口并将传入请求分发到 <strong>worker</strong> 进程。这涉及到解决三个核心主题:<strong>进程间通信 (IPC)</strong>、<strong>负载平衡策略</strong>和<strong>多进程端口监听</strong>。</p>

<h2>
  
  
  进程间通信(IPC)
</h2>

<p><strong>master</strong>进程使用process.fork()创建子进程。这些进程之间的通信是通过 <strong>IPC 通道</strong> 处理的。操作系统提供了多种进程间通信的机制,例如:</p>

<ol>
<li>
<strong>共享内存</strong>
多个进程共享一个内存空间,通常通过信号量进行管理以实现同步和互斥。</li>
<li><p><strong>消息传递</strong><br><br>
通过发送和接收消息来处理交换数据。</p></li>
<li><p><strong>信号量</strong><br><br>
信号量是系统分配的状态值。缺乏控制的进程将被迫在特定的检查点停止,等待继续进行的信号。当仅限于二进制值(0 或 1)时,此机制称为“互斥锁”(互斥锁)。</p></li>
<li><p><strong>管道</strong><br><br>
管道连接两个进程,允许一个进程的输出作为另一个进程的输入。这可以使用管道系统调用来创建。 | 的 | shell 脚本中的命令是这种机制的一个常见示例。</p></li>
</ol>

<p>Node.js 使用基于事件的机制在父进程和子进程之间进行通信。这是父进程向子进程发送 TCP 服务器句柄的示例:<br>
</p>

<pre class="brush:php;toolbar:false">const cluster = require('cluster');
const os = require('os');

if (cluster.isMaster) {
  for (let i = 0, n = os.cpus().length; i 



<h2>
  
  
  负载均衡策略
</h2>

<p>如前所述,所有请求均由 <strong>master</strong> 进程分发。确保服务器负载在工作进程之间均匀分布需要负载平衡策略。 Node.js 默认使用 <strong>round-robin</strong> 算法。</p>

<h3>
  
  
  循环赛
</h3>

<p>轮询方法是 Nginx 也采用的常见负载均衡算法。它的工作原理是按顺序将传入请求分发到每个进程,从第一个进程开始,到达最后一个进程后循环返回。然而,该方法假设所有进程的处理能力相同。在请求处理时间变化较大的场景下,可能会出现负载不平衡的情况。</p>

<p>为了解决这个问题,Nginx 经常使用<strong>加权循环(WRR)</strong>,其中服务器被分配不同的权重。选择权重最高的服务器,直到其权重减少到零,此时根据新的权重序列重新开始循环。</p>

<p>您可以通过设置 NODE_CLUSTER_SCHED_POLICY 环境变量或通过 cluster.setupMaster(options) 配置来调整 Node.js 中的负载均衡策略。结合 Nginx 进行多机集群和 Node.js Cluster 进行单机多进程平衡是一种常见的做法。</p>

<h2>
  
  
  多进程端口监听
</h2>

<p>在 Node.js 的早期版本中,侦听同一端口的多个进程会竞争传入连接,从而导致负载分布不均匀。后来通过循环赛策略解决了这个问题。当前方法的工作原理如下:</p>

<ol>
<li>
<strong>master</strong> 进程创建一个套接字,将其绑定到一个地址,并开始监听。</li>
<li>套接字的文件描述符(fd)不会传递给工作进程。</li>
<li>当主进程接受新连接时,它会确定哪个工作进程应该处理该连接并相应地转发它。</li>
</ol>

<p>本质上,主进程监听端口并使用定义的策略(例如,循环)将连接分配给工作进程。这种设计消除了worker之间的竞争,但要求master进程高度稳定。</p><h2>
  
  
  结论
</h2>

<p>本文以 PM2 的 Cluster 模式为切入点,探讨了 Node.js 的 Cluster 模块实现多进程应用程序背后的核心原理。我们重点关注三个关键方面:进程间通信、负载均衡和多进程端口监听。</p>

<p>通过研究Cluster模块,我们可以看到很多基本原理和算法是通用的。例如,循环算法被用于操作系统进程调度和服务器负载平衡。 master-worker架构类似于Nginx中的多进程设计。同样,信号量和管道等机制在各种编程范例中也无处不在。</p>

<p>虽然新技术不断涌现,但它们的基础始终如一。了解这些核心概念使我们能够自信地推断和适应新的挑战。</p>


<hr>

<h3>
  
  
  我们是 Leapcell,是将 Node.js 项目部署到云端的首选。
</h3>

<p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/173689747511076.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Understanding Node.js Cluster: The Core Concepts"></p>

<p>Leapcell 是用于 Web 托管、异步任务和 Redis 的下一代无服务器平台:</p>

<p><strong>多语言支持</strong></p>

  • 使用 Node.js、Python、Go 或 Rust 进行开发。

免费部署无限个项目

  • 只需支付使用费用——无请求,不收费。

无与伦比的成本效率

  • 即用即付,无闲置费用。
  • 示例:25 美元支持 694 万个请求,平均响应时间为 60 毫秒。

简化的开发者体验

  • 直观的用户界面,轻松设置。
  • 完全自动化的 CI/CD 管道和 GitOps 集成。
  • 实时指标和日志记录以获取可行的见解。

轻松的可扩展性和高性能

  • 自动扩展,轻松处理高并发。
  • 零运营开销——只需专注于构建。

在文档中探索更多信息!

Understanding Node.js Cluster: The Core Concepts

在 X 上关注我们:@LeapcellHQ


阅读我们的博客

以上是了解 Node.js 集群:核心概念的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
在JavaScript中替换字符串字符在JavaScript中替换字符串字符Mar 11, 2025 am 12:07 AM

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

8令人惊叹的jQuery页面布局插件8令人惊叹的jQuery页面布局插件Mar 06, 2025 am 12:48 AM

利用轻松的网页布局:8个基本插件 jQuery大大简化了网页布局。 本文重点介绍了简化该过程的八个功能强大的JQuery插件,对于手动网站创建特别有用

构建您自己的Ajax Web应用程序构建您自己的Ajax Web应用程序Mar 09, 2025 am 12:11 AM

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

如何创建和发布自己的JavaScript库?如何创建和发布自己的JavaScript库?Mar 18, 2025 pm 03:12 PM

文章讨论了创建,发布和维护JavaScript库,专注于计划,开发,测试,文档和促销策略。

使用AJAX动态加载盒内容使用AJAX动态加载盒内容Mar 06, 2025 am 01:07 AM

本教程演示了创建通过Ajax加载的动态页面框,从而可以即时刷新,而无需全页重新加载。 它利用jQuery和JavaScript。将其视为自定义的Facebook式内容框加载程序。 关键概念: Ajax和JQuery

10个JQuery Fun and Games插件10个JQuery Fun and Games插件Mar 08, 2025 am 12:42 AM

10款趣味横生的jQuery游戏插件,让您的网站更具吸引力,提升用户粘性!虽然Flash仍然是开发休闲网页游戏的最佳软件,但jQuery也能创造出令人惊喜的效果,虽然无法与纯动作Flash游戏媲美,但在某些情况下,您也能在浏览器中获得意想不到的乐趣。 jQuery井字棋游戏 游戏编程的“Hello world”,现在有了jQuery版本。 源码 jQuery疯狂填词游戏 这是一个填空游戏,由于不知道单词的上下文,可能会产生一些古怪的结果。 源码 jQuery扫雷游戏

如何为JavaScript编写无曲奇会话库如何为JavaScript编写无曲奇会话库Mar 06, 2025 am 01:18 AM

此JavaScript库利用窗口。名称属性可以管理会话数据,而无需依赖cookie。 它为浏览器中存储和检索会话变量提供了强大的解决方案。 库提供了三种核心方法:会话

jQuery视差教程 - 动画标题背景jQuery视差教程 - 动画标题背景Mar 08, 2025 am 12:39 AM

本教程演示了如何使用jQuery创建迷人的视差背景效果。 我们将构建一个带有分层图像的标题横幅,从而创造出令人惊叹的视觉深度。 更新的插件可与JQuery 1.6.4及更高版本一起使用。 下载

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。