首頁 web前端 js教程 nodejs垃圾回收的詳細介紹

nodejs垃圾回收的詳細介紹

Oct 25, 2018 pm 04:08 PM
node.js

這篇文章帶給大家的內容是關於nodejs垃圾回收的詳細介紹,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

nodejs的垃圾回收機制是由v8引擎自動管理的。

nodejs的記憶體限制

在一般的後端語言(php)來說,記憶體的使用上是沒有限制的,但對於nodejs來說只能使用系統的部分----64位元系統為1.4G,32位元系統位0.7G。這時如果你要處理個3G檔進行資料分析,即使系統的記憶體為8G,在該nodejs進程記憶體還是會溢位。

造成上面這個問題主要是因為nodejs是基於v8的,nodejs是透過v8自己的方式來管理記憶體的。那v8為什麼要限制堆記憶體的大小呢?原因有2:

1、表層原因:v8是為瀏覽器設計的,不太可能遇到大記憶體的情境。

2.深層原因:v8垃圾回收機制的限制。以1.5G的堆內存為例,v8做一次小的垃圾回收需要50ms,做一次非增量的垃圾回收要1s。垃圾回收時會造成js的執行緒的暫停,在這樣的時間花銷下,應用的效能、反應能力會直線下降。

記憶體限制是可以開啟的:
 --max-old-space-size(老生代)
 --max-new-space-size(新生代)
 v8堆記憶體大小= 老生代新生代

v8垃圾回收機制
v8垃圾回收主要是基於分代垃圾回收機制。依物件的存活時間將記憶體的垃圾回收進行不同的分代,分別對不同的分代記憶體進行不同的演算法。

新生代--->存活時間較短的物件
老生代--->存活時間較長或常駐記憶體的物件
上面也說過,nodejs堆內存的大小是新生代記憶體空間加上老生代記憶體空間。

新生代演算法
新生代主要是透過scavenge演算法進行垃圾回收。

這是一種採用複製的方式來實現垃圾回收,將堆記憶體一分為二,每個空間稱為semispace。在這2個semispace空間中,只有一個處於使用中(稱為from空間),另一個則處於空閒(稱為to空間)。開始分配時先從from空間開始,當開始垃圾回收時,也是從from空間開始檢查存活對象,把存活對象複製到to空間,而非存活對象佔用的空間就會被釋放。完成複製後,from空間和to空間角色對調。
從上面的過程可以知道,scavenge的缺點就是只使用了一半的堆內存,犧牲空間獲取時間。

老生代透過mark-sweep、mark-comopact演算法。

mark-sweep標記清除,分為標記、清除2個階段。 mark-sweep先在標記階段遍歷堆記憶體中的所有對象,並標記存活的對象;在清除階段把沒有被標記的對象清除。可以看出,scavenge只複製存活的對象,mark-sweep只清理死亡的對象。因為在新生代中存活的對象佔用小部分,而在老生代中死亡對象佔用小部分,這是這2中算法高效的原因。

Mark-compact標記整理,mark-sweep中會出現一個問題,回收後,對記憶體會出現不連續的狀態(記憶體片段)。記憶體碎片會對後續的記憶體分配造成影響,因為會有這樣一種情況:需要分配個大內存,而所有記憶體碎片都無法完成分配,這會提前觸發垃圾回收,而這個回收時不必要的。 Mark-compact是在Mark-sweep基礎上演變而來的,它主要區別在於:物件被標記後,在整理的過程中會將存活的物件都往一端移動,移動完成後直接清除。

小結:在正常的使用過程中,v8的記憶體限制還是夠用的,但nodejs的垃圾回收、單執行緒還是會影響效能。想要高性能,需要讓垃圾回收盡量小。在實際的開發中要老生代對象的使用,如實現web服務的會話(session),一般會通過內存來存儲(數組),在訪問量大的情況下會導致老生代對象劇增,有可能造成溢出。如果要處理大記憶體的數據,例如讀取3G的文件,我們會透過可讀流的pipe()方法,這樣就不會受到v8記憶體的限制影響,提高了nodejs程式的健全性。

#

以上是nodejs垃圾回收的詳細介紹的詳細內容。更多資訊請關注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

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

熱工具

記事本++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 教程
1422
52
Laravel 教程
1316
25
PHP教程
1267
29
C# 教程
1239
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