连接到MongoDB时发出警告:"警告:检测到可能的EventEmitter内存泄漏"

时间:2014-09-24 13:55:21

标签: node.js mongodb eventemitter

我在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)

2 个答案:

答案 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删除限制(据我所知)。

相关问题