900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > 【读书笔记】《深入浅出nodejs》第五章 内存控制

【读书笔记】《深入浅出nodejs》第五章 内存控制

时间:2023-04-22 08:43:51

相关推荐

【读书笔记】《深入浅出nodejs》第五章 内存控制

海量请求+长时间运行 -> 内存控制 -> 一切资源高效循环利用

1. V8的垃圾回收机制与内存限制

在Node中通过JavaScript使用内存时,只能使用部分内存(64位系统下约1.4GB,32位系统下约为0.7GB)。

在V8中,所有的JavaScript对象都是通过堆来进行分配的,当申请的堆空闲内存不够分配新的对象,将继续申请堆内存,直到堆得大小超过V8的限制为止。

为什么V8要限制堆得大小?

-> (1)V8最初为浏览器设计,不太可能遇到用大量内存的场景。

-> (2)V8的垃圾回收机制限制。(1.5GB的垃圾回收堆内存,需要大约50毫秒以上,这使得应用性能和响应能力会直线下降)

突破V8限制:

-> $node --max-old-space-size = 1700 (单位MB) or

-> $node --max-new-space-size =1024 (单位KB)

V8的垃圾回收机制 ---- 分代式垃圾回收机制

查看垃圾回收机制 ---- $node --trace_gc -e "var a = [];for (var i=0; i<1000000; i++) a.push(new Array(100));" > gc.log

2. 高效使用内存

(1)了解作用域

(2)了解闭包

无法立即回收的内存有:

->闭包

->全局变量引用

因此,要小心此类变量的无限制添加

3. 内存指标

--会存在一些我们认为会回收但是却没有被回收的对象,这会导致内存占用无限增长。一旦增长达到V8内存限制,将会得到内存溢出错误,进而导致进程退出。

(1)查看内存使用情况 -> $node >process.memoryUsage() {

{

rss (resident set size 进程的常驻内存部分):132852672, (除此外,内存其余部分在交换区(swap)或文件系统(filesystem)中)

heapTotal(堆中总共申请的内存量) :6131200,

heapUsed(目前堆中使用中的内存量):2757120,

}

(2)查看系统内存占用

-> $node >os.totalmem() “系统的总内存”

-> $node >os.freemem() “系统的闲置内存”

(3)堆外内存

受V8的垃圾回收限制的主要是V8的堆内存。

4. 内存泄漏

造成内存泄漏的原因:

(1)缓存

(2)队列消费不及时

(3)作用域未释放

5. 内存泄漏排查

使用常见工具:

(1)node-heapdump

(2)node-memwatch

6. 大内存应用

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。