FATAL ERROR: Ineffective mark-compacts near heap limit Allocation failed - JavaScript heap out...

FATAL ERROR: Ineffective mark-compacts near heap limit Allocation failed - JavaScript heap out of memory


标题为ant-design-pro+umijs 启动时内存溢出的报错信息,详细报错信息见下图。

<--- Last few GCs --->

[20940:00000244699848E0]   215872 ms: Scavenge 1690.2 (1836.4) -> 1679.6 (1836.4) MB, 5.4 / 0.7 ms  (average mu = 0.266, current mu = 0.253) allocation failure
[20940:00000244699848E0]   216022 ms: Scavenge 1699.5 (1844.0) -> 1682.3 (1837.9) MB, 9.8 / 4.0 ms  (average mu = 0.266, current mu = 0.253) allocation failure
[20940:00000244699848E0]   216476 ms: Scavenge 1694.6 (1837.9) -> 1685.7 (1837.9) MB, 15.7 / 0.3 ms  (average mu = 0.266, current mu = 0.253) external memory pressure


<--- JS stacktrace --->

FATAL ERROR: Ineffective mark-compacts near heap limit Allocation failed - JavaScript heap out of memory
 1: 00007FF6806D401F v8::internal::CodeObjectRegistry::~CodeObjectRegistry+112511
 2: 00007FF680663146 DSA_meth_get_flags+65542
 3: 00007FF680663FFD node::OnFatalError+301
 4: 00007FF680F95ADE v8::Isolate::ReportExternalAllocationLimitReached+94
 5: 00007FF680F8000D v8::SharedArrayBuffer::Externalize+781
 6: 00007FF680E235FC v8::internal::Heap::EphemeronKeyWriteBarrierFromCode+1468
 7: 00007FF680E302A9 v8::internal::Heap::PublishPendingAllocations+1129
 8: 00007FF680E2D27A v8::internal::Heap::PageFlagsAreConsistent+2842
 9: 00007FF680E1FEF9 v8::internal::Heap::CollectGarbage+2137
10: 00007FF680E2879B v8::internal::Heap::GlobalSizeOfObjects+331
11: 00007FF680E6ECCB v8::internal::StackGuard::HandleInterrupts+891
12: 00007FF680B776D6 v8::internal::DateCache::Weekday+8630
13: 00007FF6810234B1 v8::internal::SetupIsolateDelegate::SetupHeap+494417
14: 000002446C59367C
Done in 218.33s.

在报错信息中明显提示内存不足,解决方法也很简单,设置max-old-space-size即可。在工程目录node_modules.bin下找到umi.cmd文件,替换下面代码,重新启动即可。

@IF EXIST "%~dp0\node.exe" (
  "%~dp0\node.exe" --max_old_space_size=8192 "%~dp0\..\umi\bin\umi.js" %*
) ELSE (
  @SETLOCAL
  @SET PATHEXT=%PATHEXT:;.JS;=;%
  node  --max_old_space_size=8192 "%~dp0\..\umi\bin\umi.js" %*
)

其中‘–max_old_space_size’的值可根据自身情况设置。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GC (Allocation Failure) 是一种垃圾回收机制,它表示在进行内存分配时,发生了分配失败的情况。当程序需要为对象分配内存空间时,如果没有足够的连续内存空间可用,就会触发GC (Allocation Failure)。这种GC通常发生在新生代内存区域,并伴随着Minor GC操作。 在这种情况下,垃圾收集器会回收一些不再使用的对象,释放它们占用的内存空间,以便为新的对象分配空间。在GC (Allocation Failure)之后,会有一些相关的信息被记录下来,如GC前该内存区域(这里是老年代)的使用容量,GC后该内存区域的使用容量和该内存区域的总容量。这些信息可以用来分析内存使用情况和垃圾回收效果。 所以,当你在程序日志中看到GC (Allocation Failure)的信息时,它表示在内存分配过程中发生了分配失败,并触发了相应的垃圾回收操作。这是一种正常的GC行为,用于保证程序的内存使用效率和稳定性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [GC(Allocation Failure)解读](https://blog.csdn.net/crq1205/article/details/109054240)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值