目錄
進程
#執行緒
首頁 web前端 js教程 Node.js真的是單線程嗎?進程間如何通訊?

Node.js真的是單線程嗎?進程間如何通訊?

Aug 02, 2021 pm 06:44 PM
node.js 單執行緒

這篇文章跟大家介紹一下進程和線程,帶大家了解一下Node.js中的線程,看看node真的單線程嗎、child_process和cluster模組,並簡單聊聊多線程之間如何通信。

Node.js真的是單線程嗎?進程間如何通訊?

進程

在作業系統中,對進程的解釋:進程是一個具有一定獨立功能的程式在一個數據集上的一次動態執行的過程,是作業系統進行資源分配和調度的一個獨立單位,是應用程式運作的載體。

  • 是應用程式的一次運行過程(動態概念)

  • #是系統分配和調度資源的基本單位(進程是一般由程序、資料集合與進程控制塊三部分組成)

  • 每個進程有自己獨立的空間位址,資料棧(各進程間資料不共享,可透過其他方式進行通訊)行程一般有初始態,執行態,等待狀態,就緒狀態,終止狀態五種狀態

#執行緒

##執行緒是程式執行中一個單一的順序控制流程,是程式執行流的最小單元,是處理器調度和分派的基本單位。

  • 任務排程與執行的最小單位

  • #一個行程中程式碼單一執行路線

行程與執行緒區別

執行緒是程式執行的最小單位,行程是作業系統分配資源的最小單位一個行程由一個或多個執行緒組成,執行緒是一個行程中程式碼的不同執行路線進程間相互獨立,但同一進程下各線程之間共享程序的內存空間線程上下文切換比進程上下文切換要快

node中進程

#node是單執行緒的,即一個行程只開一個執行緒node。 【推薦學習:《

nodejs 教學》】

真的單執行緒嗎?

Node  雖然是單線程,但其底層是多線程的。事件循環中,libuv庫從事件佇列中取出任務再分配給不同的執行緒進行處理。現在硬體條件沒有以前那麼落後,如果只使用單執行緒進行操作,則會浪費資源。所以,為了實現多進程處理,充分發揮多核心CPU的優勢,Node提供了child_process模組和cluster模組。

  • child_process模組用於開啟多個子進程,子進程中執行不同的命令或執行node.js模組檔案、可執行檔

  • Cluster模組,叢集模組,用於實作在Node.js應用程式中開啟多個子進程,每個子進程中執行一個Node.js應用程式副本的處理

child_process模組

  • child_process.spawn():適用於傳回大量數據,例如映像處理,二進位資料處理。

  • child_process.exec():適用於小量數據,maxBuffer 預設值為 200 * 1024 超出這個預設值將會導致程式崩潰,資料量過大可採用 spawn。

  • child_process.execFile():類似child_process.exec(),差異是無法透過shell 來執行,不支援像I/O 重定向和檔案尋找這樣的行為

  • child_process.fork(): 衍生新的進程,進程之間是相互獨立的,每個進程都有自己的V8 實例、內存,系統資源是有限的,不建議衍生太多的子行程出來,通常會根據系統* CPU 核心數設定。

cluster模組

  • #cluster.fork([env]) 開啟子程序,子程序中建立一個Node .js應用程式的實例

  • isMaster屬性和isWorker屬性用來判斷是運行在主程序中,還是運行在子程序中

  • Workers屬性用來取得所有子行程中執行的worker物件

擴充功能一下,多執行緒之間如何通訊?

進程間的通訊

四種:

  • #訊息傳遞(管道、FIFO、訊息佇列)

  • 信號量(互斥量、條件變數、讀寫鎖定)

  • #共享記憶體(匿名、命名)

  • #遠端過程呼叫

進程間的通訊不只在node中會遇到,其實在其他語言都會遇到的,當然在面試中也是必提問的問題吧。

很多內容都可以進行深入擴展討論!

更多程式相關知識,請造訪:

程式設計入門! !

以上是Node.js真的是單線程嗎?進程間如何通訊?的詳細內容。更多資訊請關注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脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 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)

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

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

圖文詳解Node V8引擎的記憶體和GC 圖文詳解Node V8引擎的記憶體和GC Mar 29, 2023 pm 06:02 PM

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

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

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

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

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

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

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

聊聊Node.js中的 GC (垃圾回收)機制 聊聊Node.js中的 GC (垃圾回收)機制 Nov 29, 2022 pm 08:44 PM

Node.js 是如何做 GC (垃圾回收)的?下面這篇文章就來帶大家了解一下。

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

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

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

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

See all articles