首頁 web前端 js教程 Node.js中關於多進程模組Cluster的詳細介紹以及如何使用

Node.js中關於多進程模組Cluster的詳細介紹以及如何使用

May 27, 2017 am 10:44 AM

眾所周知Node.js是單執行緒的,一個單獨的Node.js進程無法充分利用多核心。 Node.js從v0.6.0開始,新增cluster模組,讓Node.js開發Web服務時,很方便的做到充分利用多核心機器。這篇文章主要跟大家介紹了關於Node.js中多進程模組Cluster的相關資料,需要的朋友可以參考下

##前言

#我們都知道nodejs最大的特點就是單一進程、無阻塞運行,而且是非同步事件驅動的。 Nodejs的這些特性能夠很好的解決一些問題,例如在伺服器開發中,並發的請求處理是個大問題,阻塞式的函數會導致資源浪費和時間延遲。透過事件註冊、非同步函數,開發人員可以提高資源的利用率,效能也會改善。既然Node.js採用單一流程、單執行緒模式,那麼在現今多核心硬體流行的環境中,單核心效能出色的Nodejs如何利用多核心CPU呢?創辦人Ryan Dahl建議,運行多個Nodejs進程,利用某些通訊機制來協調各項任務。目前,已經有不少第三方的Node.js多進程支援模組發布,而NodeJS 0.6.x 以上的版本提供了一個cluster模組,允許創建“共享同一個socket”的一組進程,用來分擔負載壓力。

本篇文章就基於該cluster模組來講述Node.js在多核心CPU下的程式設計。

Cluster模組介紹

nodejs所提供的cluster模組目前尚處於試驗階段,在v0.10.7的官方文件上我們可以看到模組的發佈資訊如下:


Stability: 1 - Experimental
登入後複製

關於該模組的功能,來源文件描述如此「A single instance of Node runs in a single thread. To take advantage of multi -core systems the user will sometimes want to launch a cluster of Node processes to handle the load.」 其意指:Node的範例以單一進程的模式運行,有時為了充分利用多核心系統的資源使用者需要運行一組Node進程來分擔負載。

Cluster用法介紹

先貼出一段模組範例應用程式碼,接下來進行詳細分析,程式碼如下:


var cluster = require('cluster');
var http = require('http');
var numCPUs = require('os').cpus().length;

if (cluster.isMaster) {
 require('os').cpus().forEach(function(){
 cluster.fork();
 });
 cluster.on('exit', function(worker, code, signal) {
 console.log('worker ' + worker.process.pid + ' died');
 });
 cluster.on('listening', function(worker, address) { 
 console.log("A worker with #"+worker.id+" is now connected to " +
  address.address +
 ":" + address.port); 
 }); 
} else {
 http.createServer(function(req, res) {
 res.writeHead(200);
 res.end("hello world\n");
 console.log('Worker #' + cluster.worker.id + ' make a response');
 }).listen(8000);
}
登入後複製

這段程式碼很簡單,主執行緒就是目前運行的js文件,主執行緒根據你本機系統的核數來創建子程序。所有行程共用一個監聽埠8000,當有請求發起時,主執行緒會將該請求隨機分配給某個子程序。

console.log('Worker #' + cluster.worker.id + ' make a response');這句程式碼可以列印出是哪個行程處理該請求。

問題分析

我們前面提到有請求發起時,由系統決定將該請求交給哪個程序處理。這種完全依賴系統的負載平衡有一個重要缺陷:在windows,linux和Solaris上,只要某個子程序的accept queue為空(通常為最後創建的那個子程序),系統就會將多個connetion分配到同一個子進程上,這會造成進程間負載極為不平衡。特別是使用長連接的時候,單位時間內的new coming connection並不高,子進程的accept queue往往均為空,就會導致connection會不停的分配給同一個進程。所以這種負載平衡完全依賴accept queue的空閒程度,只有在使用短連接,而且並發非常高的情況下,才能達到負載平衡,但這個時候系統的load會非常高,系統也會變得不穩定起來。

總結#

以上是Node.js中關於多進程模組Cluster的詳細介紹以及如何使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
圖文詳解Node V8引擎的記憶體和GC 圖文詳解Node V8引擎的記憶體和GC Mar 29, 2023 pm 06:02 PM

這篇文章帶大家深入了解NodeJS V8引擎的記憶體和垃圾回收器(GC),希望對大家有幫助!

一文聊聊Node中的記憶體控制 一文聊聊Node中的記憶體控制 Apr 26, 2023 pm 05:37 PM

基於無阻塞、事件驅動建立的Node服務,具有記憶體消耗低的優點,非常適合處理海量的網路請求。在海量請求的前提下,就需要考慮「記憶體控制」的相關問題了。 1. V8的垃圾回收機制與記憶體限制 Js由垃圾回收機

聊聊如何選擇一個最好的Node.js Docker映像? 聊聊如何選擇一個最好的Node.js Docker映像? Dec 13, 2022 pm 08:00 PM

選擇一個Node的Docker映像看起來像是小事,但是映像的大小和潛在漏洞可能會對你的CI/CD流程和安全造成重大的影響。那我們要如何選擇一個最好Node.js Docker映像呢?

Node.js 19正式發布,聊聊它的 6 大功能! Node.js 19正式發布,聊聊它的 6 大功能! Nov 16, 2022 pm 08:34 PM

Node 19已正式發布,以下這篇文章就來帶大家詳解了解Node.js 19的 6 大特性,希望對大家有幫助!

深入聊聊Node中的File模組 深入聊聊Node中的File模組 Apr 24, 2023 pm 05:49 PM

文件模組是對底層文件操作的封裝,例如文件讀寫/打開關閉/刪除添加等等文件模組最大的特點就是所有的方法都提供的**同步**和**異步**兩個版本,具有sync 字尾的方法都是同步方法,沒有的都是異

一起聊聊Node中的事件循環 一起聊聊Node中的事件循環 Apr 11, 2023 pm 07:08 PM

事件循環是 Node.js 的基本組成部分,透過確保主執行緒不被阻塞來實現非同步編程,了解事件循環對建立高效應用程式至關重要。以下這篇文章就來帶大家深入了解Node中的事件循環 ,希望對大家有幫助!

聊聊用pkg將Node.js專案打包為執行檔的方法 聊聊用pkg將Node.js專案打包為執行檔的方法 Dec 02, 2022 pm 09:06 PM

如何用pkg打包nodejs可執行檔?以下這篇文章跟大家介紹一下使用pkg將Node專案打包為執行檔的方法,希望對大家有幫助!

node無法用npm指令怎麼辦 node無法用npm指令怎麼辦 Feb 08, 2023 am 10:09 AM

node無法用npm指令是因為沒有正確配置環境變量,其解決方法是:1、開啟“系統屬性”;2、找到“環境變數”->“系統變數”,然後編輯環境變數;3、找到nodejs所在的資料夾;4、點選「確定」即可。

See all articles