webpack 运行 npm run build 内存溢出 JavaScript heap out of memory

vue-cli3.0构建的项目,开发过程中,可能会遇到内存溢出的情况,改动一点代码,代码编译,进程就会断掉,报JavaScript heap out of memory 内存溢出的错误

内存溢出主要原因分析

  1. nodejs在执行JavaScript时,内存受到v8限制,64位约为1.4g,32位0.7g
  2. 限制内存原因:垃圾回收时,js线程会暂停执行(避免JS应用逻辑与垃圾回收器看到的不一样),大量的堆内存回收严重影响性能

解决思路

  1. 通过webpack进行打包优化,降低单个文件大小,比如使用dll,这个思路不是本节讲授重点
  2. 扩大node内存

思路2具体解决方案

通过解决increase-memory-limit的包升级版来解决

1. 安装两个npm包: increase-memory-limit-fixbug 和 cross-env

npm install increase-memory-limit-fixbug cross-env -g

2. package.json中 添加如下脚本

"fix-memory-limit": "cross-env LIMIT=4096 increase-memory-limit"

解决内存溢出问题_内存溢出

3. 执行fix-memory-limit脚本

npm run fix-memory-limit

4. 重新运行项目即可

npm run build

补充
如果使用increase-memory-limit而不使用increase-memory-limit-fixbug,执行完npm run fix-memory-limit,需要手动清除掉标注的地方,但是标注的地方是依赖的包文件,生产环境不好操作,所以increase-memory-limit-fixbug是对其优化,在解决内存溢出问题基础上专门解决此问题的
解决内存溢出问题_内存溢出_02

参考:

如果你觉得此文对你有一定的帮助,可以点击下方的【赞】收藏备用