节点版本号为v0.11.13

内存使用在崩溃期间根据sudo顶部不超过3%

重现此错误的代码:

var request = require('request')
var nodedump = require('nodedump')

request.get("http://pubapi.cryptsy.com/api.php?method=marketdatav2",function(err,res)
{
    var data
    console.log( "Data received." );
    data = JSON.parse(res.body)
    console.log( "Data parsed."   );
    data = nodedump.dump(data)
    console.log( "Data dumped."   ); 
    console.log( data )
})

为了检查这是否是递归堆栈大小的问题,我运行了下一个代码——stack-size=60000参数

var depth = 0;

(function recurse() {
    // log at every 500 calls
    (++depth % 500) || console.log(depth);
    recurse();
})();

并且有

264500 
Segmentation fault

然后我运行了代码,给我致命错误:CALL_AND_RETRY_LAST分配失败-进程内存不足,具有相同的-stack-size=60000参数,并且没有分割错误。

因此,我得出结论,CALL_AND_RETRY_LAST与递归堆栈大小没有任何共同之处。

我怎么解决这个问题呢?我相信我的电脑上有足够的空闲内存来成功完成这项任务。

在stackoverflow上也有类似的问题,但这些问题都不是关于CALL_AND_RETRY_LAST的,这就是为什么我创建了单独的问题。


当前回答

要解决这个问题,您需要通过使用选项max_old_space_size来增加内存限制来运行应用程序。默认情况下,Node.js的内存限制是512 mb。

node --max_old_space_size=2000  server.js 

其他回答

我发现max_new_space_size不是节点4.1.1的选项,max_old_space_size本身并不能解决我的问题。我添加以下到我的shebang和这些组合似乎工作:

#!/usr/bin/env node --max_old_space_size=4096 --optimize_for_size --max_executable_size=4096 --stack_size=4096

[编辑]:4096 === 4GB内存,如果您的设备内存较低,您可能希望选择较小的数量。

[更新]:在运行grunt时也发现了这个错误,之前是这样运行的:

./node_modules/.bin/grunt

更新命令后,它停止有内存错误:

node --max_old_space_size=2048 ./node_modules/.bin/grunt 

我在这个问题上浪费了一些日子....直到我发现我在某个文件中导入了一个静态文件,一个构建文件。它使构建永远不会结束。喜欢的东西:

import PropTypes from "../static/build/prop-types"; 

固定到真正的来源解决了所有的问题。

分享我的解决方案。:)

# !/usr/bin/env节点——max-old-space-size=4096在ionic-app-scripts.js力下工作

但修改后:下面的文件它工作

node_modules /。bin / ionic-app-scripts.cmd

通过添加:

@IF EXIST "%~dp0\node.exe" ( “% ~ dp0 \ node.exe”“% ~ dp0 . . @ionic \ app-scripts \ bin \ ionic-app-scripts.js”% * )其他( @SETLOCAL @SET列出= %列出;. js, =; % 节点——max_old_space_size=4096 "%~dp0..@ionic\app-scripts\bin\ionic-app-scripts.js" %* )

任何使用Azure构建管道遇到此错误的人,请尝试以下步骤更改构建代理的环境变量

添加一个Azure构建管道任务-> Azure powershell脚本:Inlinescript在Compile之前,使用以下设置

- task: AzurePowerShell@3
  displayName: 'Azure PowerShell script: InlineScript'
  inputs:
    azureSubscription: 'NYCSCA Azure Dev/Test (ea91a274-55c6-461c-a11d-758ef02c2698)'
    ScriptType: InlineScript
    Inline: '[Environment]::SetEnvironmentVariable("NODE_OPTIONS", "--max_old_space_size=16384", "Machine")'
    FailOnStandardError: true
    azurePowerShellVersion: LatestVersion

您还应该检查是否不小心安装了x86版本的node而不是x64。发生在我身上,因为nodejs.org在我的x64机器上预选了x86…