【问题标题】:nodejs setMaxListeners to avoid memory leak detectionnodejs setMaxListeners 避免内存泄漏检测
【发布时间】:2013-12-02 17:02:52
【问题描述】:

我阅读了一些其他问题和帖子,但找不到在哪里应用 .setMaxListeners(0)。 我正在使用一个简单的 websocket-server,它会出现错误:

(node) warning: possible EventEmitter memory leak detected. 11 listeners added. Use emitter.setMaxListeners() to increase limit.
Trace
at Socket.EventEmitter.addListener (events.js:160:15)
at Socket.Readable.on (_stream_readable.js:689:33)
at XHRPolling.Transport.setHandlers            (D:\nodeJS\host\node_modules\socket.io\lib\transport.js:116:15)
at XHRPolling.HTTPPolling.setHandlers        (D:\nodeJS\host\node_modules\socket.io\lib\transports\http-polling.js:53:39)
at XHRPolling.Transport.handleRequest (D:\nodeJS\host\node_modules\socket.io\lib\transport.js:70:10)
at XHRPolling.HTTPTransport.handleRequest (D:\nodeJS\host\node_modules\socket.io\lib\transports\http.js:84:39)
at XHRPolling.HTTPPolling.handleRequest (D:\nodeJS\host\node_modules\socket.io\lib\transports\http-polling.js:73:41)
at XHRPolling.Transport (D:\nodeJS\host\node_modules\socket.io\lib\transport.js:31:8)
at XHRPolling.HTTPTransport (D:\nodeJS\host\node_modules\socket.io\lib\transports\http.js:29:13)
at XHRPolling.HTTPPolling (D:\nodeJS\host\node_modules\socket.io\lib\transports\http-polling.js:27:17)

我正在以这种方式实例化路由器:

var app = require('http').createServer(handler)
, io = require('socket.io').listen(app, { log: false })
, fs = require('fs');
app.listen(8070);

然后我正在监听传入的套接字请求:

io.sockets.on('connection', function (socket) {

       socket.on('createTake', function(data){...}
});

我可以在哪里应用 MaxListener?

我已经试过了:

io.sockets.on(...).setMaxListeners(0);

但它不起作用。

【问题讨论】:

    标签: node.js socket.io


    【解决方案1】:

    您正在将侦听器附加到 io.sockets (io.sockets.on(...))。您应该将 setMaxListeners 应用于同一个对象(到 EventEmmiter)。所以试试:

    io.sockets.setMaxListeners(0);
    

    【讨论】:

    • tyvm。我只是无法想象在哪里设置它。现在它可以工作了:)
    • 欢迎您。但不要轻易忽视这个警告。当不再需要监听器时,检查是否不应该在代码中的某处删除监听器。如果您只需要对事件做出一次反应,请使用 io.sockets.once(...)
    【解决方案2】:

    这由“maxListeners”选项控制。您有 2 种方法:完全禁用内存泄漏(我不建议这样做)或增加 maxListeners。

    1.为了保持功能活跃,不要太激进:

    默认值为 10,增加此值以保持内存泄漏检测处于活动状态,但不那么激进。输入您需要的任何数字。如果您实际上不知道您将使用多少个听众,我将从小步骤开始。错误地,您得到了当时您附加了多少听众的数字。

    io.sockets.setMaxListeners(15);
    

    2。完全禁用内存泄漏功能:

    io.sockets.setMaxListeners(0);
    

    其他相关提示:

    获取当前值:

    io.sockets.getMaxListeners();
    

    如果您只需要对事件做出一次反应,请使用 io.sockets.once(...) 它将删除未使用的侦听器。 tomekK

    【讨论】:

    • 是否有我可以收听的事件,以便我可以知道何时达到此最大监听器。
    • 您可以等待内存泄漏错误消息warning: possible EventEmitter memory leak detected. 11 listeners added. Use emitter.setMaxListeners() to increase limit. Trace,然后按您的意愿处理。
    • 我应该听什么事件
    • @SanthoshSKashyap 没有。只需捕获错误并解析消息,如果这不是您正在等待的错误,请再次抛出它。这可能会有所帮助:stackoverflow.com/questions/7310521/…
    猜你喜欢
    • 1970-01-01
    • 2018-04-08
    • 2013-06-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-07-16
    相关资源
    最近更新 更多