我在Node.js中遇到Event Emitter警告问题。我正在尝试使用Mongoskin连接到MongoDB。您能否向我解释为什么警告正在发生以及如何避免警告?
for (j in self.channel_data) {
( function( channel, index ) {
mongo.collection('revenue_share')
.find({ approved: true,
entity_id: channel.user_channel_id,
date_effective: {$lte: +new Date(self.report_data[channel.report_id].end_date).getTime()}
}, selectables)
.sort({date_effective : -1})
.toArray(function (err, _data) {
if (err || !_data.length) {
return self.fetched_rev_share(channel, null);
}
return self.fetched_rev_share(channel, _data[0]);
});
})(self.channel_data[j], j);
}
以下是显示的警告:
(node) warning: possible EventEmitter memory leak detected. 51 listeners added. Use emitter.setMaxListeners() to increase limit.
Trace
at EventEmitter.addListener (events.js:160:15)
at EventEmitter.once (events.js:185:8)
at SkinClass.open (/Users/ninz/Sites/freedom-node-backend/node_modules/mongoskin/lib/utils.js:156:23)
at SkinClass.SkinCollection._open (/Users/ninz/Sites/freedom-node-backend/node_modules/mongoskin/lib/collection.js:49:17)
at SkinClass.open (/Users/ninz/Sites/freedom-node-backend/node_modules/mongoskin/lib/utils.js:162:14)
at SkinClass.SkinCursor._open (/Users/ninz/Sites/freedom-node-backend/node_modules/mongoskin/lib/cursor.js:28:25)
at SkinClass.open (/Users/ninz/Sites/freedom-node-backend/node_modules/mongoskin/lib/utils.js:162:14)
at SkinClass.(anonymous function) [as sort] (/Users/ninz/Sites/freedom-node-backend/node_modules/mongoskin/lib/utils.js:116:14)
at /Users/ninz/Sites/freedom-node-backend/helpers/channel_earnings.js:61:18
at Query.loop_to_channels [as _callback] (/Users/ninz/Sites/freedom-node-backend/helpers/channel_earnings.js:70:7)
答案 0 :(得分:0)
您正在执行的代码(我假设它是因为self.channel_data
包含51个密钥)导致51个侦听器被添加到EventEmitter。为了帮助防止内存泄漏,当您添加超过n
个侦听器(默认情况下为10)时,EventEmitters会抛出警告 - 在这种情况下您执行此操作。
为了解决这个问题,你需要将EventEmitter最大侦听器数量设置为51以上 - 比方说75. Here are the docs for that change。
eventemitter.setMaxListeners(75);
我没有足够的经验使用Mongo驱动程序来确定eventemitter
的位置,但这就是错误。
答案 1 :(得分:0)
如果查看node_modules/mongoskin/lib/utils.js
,您可以在第45行看到他们专门将最大侦听器设置为50。
this._emitter.setMaxListeners(50);
你可以做的是全局改变它,或者只是在js文件中自己编辑它。
this._emitter.setMaxListeners(0);
0删除限制(据我所知)。