节点版本号为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的,这就是为什么我创建了单独的问题。


当前回答

任何使用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

其他回答

npm install -g increase-memory-limit

increase-memory-limit

OR

导航到%appdata% -> npm文件夹或C:\Users\{user_name}\ appdata \Roaming\npm 打开ng。在您最喜欢的编辑器中的CMD 在IF和ELSE块中添加——max_old_space_size=8192

现在ng。修改后的CMD文件如下所示:

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

我的工作解决方案是:

安装cross-env NPM install——save-dev cross-env或NPM install -g cross-env 文件包。Json添加新的构建脚本 如。 ... "cross-env NODE_OPTIONS='——max-old-space-size=8192' ionic cordova build ios -prod -release" ... 下次使用该命令进行构建。 NPM运行build:prod:ios 问题解决了。

当分配给执行所需的内存小于运行进程所需的内存时,发生此错误。默认情况下,节点内存大小为512 mb,您需要输入以下命令来增加内存大小:

node --max-old-space-size= <NewSize> <fileName>

当我创建一个react-native包时,我看到了这个问题。 我尝试过但没有成功的事情:

增加节点——max_old_space_size,有趣的是,这在本地为我工作,但在jenkins上失败了,我仍然不确定jenkins出了什么问题 有些地方提到将node的版本降级到6.9.1,但我也没有这样做。我只是想把这个放在这里,因为它可能对你有用。

对我有用的东西: 我在代码中导入了一个很大的文件。我解决这个问题的方法是将它包含在.babelrc的忽略列表中,就像这样:

{
    "presets": ["react-native"],
    "plugins": ["transform-inline-environment-variables"],
    "ignore": ["*.json","filepathToIgnore.ext"]
}

它是一个.js文件,实际上不需要转译,将它添加到忽略列表确实有帮助。

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

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

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

分享我的解决方案。:)