nodejs垃圾回收的详细介绍

本篇文章给大家带来的内容是关于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垃圾回收的详细介绍的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2738016.html

(0)
上一篇 2025年3月8日 01:43:21
下一篇 2025年3月8日 01:43:30

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • js闭包的代码示例讲解

    本篇文章给大家带来的内容是关于js闭包的代码示例讲解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 准确来说,闭包是基于正常的垃圾回收处理机制下的。也就是说,一般情况一个函数(函数作用域)执行完毕,里面声明的变量会全部释放…

    编程技术 2025年3月8日
    200
  • Node.js解决循环依赖问题的两种方法介绍

    本篇文章给大家带来的内容是关于node.js解决循环依赖问题的两种方法介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 本文重点是讲解如何解决循环依赖这个问题。关心这个问题是如何产生的,可以自行谷歌。 如何重现这个问题 …

    2025年3月8日
    200
  • javascript数组常用的遍历方法(代码示例)

    本篇文章给大家带来的内容是关于javascript数组常用的遍历方法(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 前言 本文主要介绍数组常见遍历方法:forEach、map、filter、find、every…

    2025年3月8日
    200
  • 使用node express框架实现文件的上传(代码示例)

    本篇文章给大家带来的内容是关于使用node express框架实现文件的上传(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 本文主要采用node express框架实现,模板引擎用的是ejs 这是app.js文…

    编程技术 2025年3月8日
    200
  • Node.js中操作MySQL数据库的基础教程

    本篇文章给大家带来的内容是关于node.js中操作mysql数据库的基础教程,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 本文是一篇使用mysql这个npm模块操作MySQL数据库的基础教程。 不涉及MySQL的安装和配…

    2025年3月8日 编程技术
    200
  • js中运行机制的详细分析(示例解析)

    本篇文章给大家带来的内容是关于js中运行机制的详细分析(示例解析),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、引子 本文介绍JavaScript运行机制,这一部分比较抽象,我们先从一道面试题入手: console.…

    2025年3月8日
    200
  • 使用node解读http缓存的内容

    本篇文章给大家带来的内容是关于使用node解读http缓存的内容,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 用node搞web服务和直接用tomcat、Apache做服务器不太一样, 很多工作都需要自己做。缓存策略也要…

    2025年3月8日
    200
  • ES6中迭代器的原理与可迭代对象的介绍(附示例)

    本篇文章给大家带来的内容是关于es6中迭代器的原理与可迭代对象的介绍(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 ES6 新的数组方法、集合、for-of 循环、展开运算符(…)甚至异步编程都依赖于…

    编程技术 2025年3月8日
    200
  • 在nodejs中读取大文本文件时遇到问题的解决方案

    本篇文章给大家介绍的内容是关于在nodejs中读取大文本文件时遇到问题的解决方案,有需要的朋友可以参考一下。 最近一直在玩NodeJS,并在尝试读取非常大的文本文件时遇到以下错误: FATAL ERROR: CALL_AND_RETRY_0…

    编程技术 2025年3月8日
    200
  • 浏览器缓存机制的深入解析(图文)

    本篇文章给大家带来的内容是关于浏览器缓存机制的深入解析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、前言 关于页面性能优化,浏览器缓存必定是一个绕不过的话题,判断一个网站的性能最直观的就是看网页打开的速度,而提高网页…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论