javascript - 递归 process.nextTick 警告

标签 javascript node.js

作为我的应用程序的一部分,我有以下代码行:

process.nextTick(function() {
  // pre-populate cache with all users
  console.log('scanning users table in order to pre-populate cache');
  tables.users.scan(function(err, users) {
    if (err) {
      console.error('unable to scan users database in order to pre-populate cache');
      return;
    }

    console.log('found %d users in database', users.length);
  });
});

在 ubuntu 中运行应用程序给了我

(node) warning: Recursive process.nextTick detected. This will break in the next version of node. Please use setImmediate for recursive deferral.

RangeError: Maximum call stack size exceeded

在 OSX 上运行良好,没有任何警告。

两者都运行相同的 Node 版本 v0.10.24

删除此代码块即可解决问题。我想弄清楚这里发生了什么。

尝试使用 --trace-deprecation 标志运行 Node

Trace: (node) warning: Recursive process.nextTick detected. This will break in the next version of node. Please use setImmediate for recursive deferral.
    at maxTickWarn (node.js:377:17)
    at process.nextTick (node.js:480:9)
    at onwrite (_stream_writable.js:260:15)
    at WritableState.onwrite (_stream_writable.js:97:5)
    at WriteStream.Socket._write (net.js:651:5)
    at doWrite (_stream_writable.js:221:10)
    at writeOrBuffer (_stream_writable.js:211:5)
    at WriteStream.Writable.write (_stream_writable.js:180:11)
    at WriteStream.Socket.write (net.js:613:40)
    at Console.warn (console.js:61:16)
    at Console.trace (console.js:95:8)
    at maxTickWarn (node.js:377:17)

运行 --throw-deprecation 给出

Error: (node) warning: Recursive process.nextTick detected. This will break in the next version of node. Please use setImmediate for recursive deferral.
    at maxTickWarn (node.js:375:15)
    at process.nextTick (node.js:480:9)
    at Cursor.each (/var/www/node_modules/mongojs/node_modules/mongodb/lib/mongodb/cursor.js:184:13)
    at /var/www/node_modules/mongojs/node_modules/mongodb/lib/mongodb/cursor.js:191:16
    at Cursor.nextObject (/var/www/node_modules/mongojs/node_modules/mongodb/lib/mongodb/cursor.js:540:5)
    at /var/www/node_modules/mongojs/node_modules/mongodb/lib/mongodb/cursor.js:187:12
    at process._tickCallback (node.js:415:13)

非常感谢任何帮助。

10倍

最佳答案

原来问题出在我在我的应用程序中使用的模块之一 - mongojs。该问题已在更高版本的模块中解决,我只需要更新我的 package.json

Jamis Charles 关于使用 node --throw-deprecation app.js(或 --trace-deprecation)运行我的应用程序的评论向我展示了错误的堆栈跟踪这让我找到了罪魁祸首模块。

我仍然不确定为什么问题出现在 Ubuntu 而不是我的 MBA 上......

关于javascript - 递归 process.nextTick 警告,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20792341/

相关文章:

JavaScript 数组推送不适用于 ng-change

Node.JS [nodemon] 内部监视失败 : ENFILE: file table overflow

javascript - 如果对象数组中只有 1 个属性设置为状态更改,整个 DOM 是否会重新渲染?

javascript - 使用 jquery 动态设置事件选项卡

node.js - 哈希字符串与哈希 UInt8Array

node.js - js应用程序API错误: Forbidden accessing App Engine datastore from local Node.

javascript - 错误 : ENOENT, 没有这样的文件或目录 '/usr/lib/nodejs:/usr/lib/node_modules:/usr/share/javascript/app/models

css - 尝试 sass --watch ./folder ./css 时 sass 编译错误

javascript - 在react中有条件地导入引导文件

javascript - raphael:如何通过代码而不是通过 "drag"在对象上启动 "mouse down"事件?