前言
如果您使用 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 整合。
- 即時指標和日誌記錄以獲取可行的見解。
輕鬆的可擴充性和高效能
- 自動擴展,輕鬆處理高並發。
- 零營運開銷-只需專注於建置。
在文件中探索更多資訊!
在 X 上追蹤我們:@LeapcellHQ
閱讀我們的部落格
以上是了解 Node.js 叢集:核心概念的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

SublimeText3漢化版
中文版,非常好用