【问题标题】:socket.io redis and memory leaksocket.io redis 和内存泄漏
【发布时间】:2012-03-07 13:13:02
【问题描述】:

我的 socket.io 版本是 socket.io@0.8.7 和 redis@0.7.1。 我在 Windows 上。

在某些地方,我已经看到问题已解决。我想我使用的是最新的 socket.io 版本。 什么是emitter.setMaxListeners(),我在哪里可以设置?

(node) warning: possible EventEmitter memory leak detected. 11 listeners added.
Use emitter.setMaxListeners() to increase limit.
Trace:
    at RedisClient.<anonymous> (events.js:133:17)
    at Socket.<anonymous> (c:\HTML5\LIKEPREF\test\server\server.js:576:18)
    at Socket.$emit (events.js:67:17)
    at SocketNamespace.handlePacket (C:\Personal\software\nodejs\NODE\node_modul
es\socket.io\lib\namespace.js:335:22)
    at Manager.onClientMessage (C:\Personal\software\nodejs\NODE\node_modules\so
cket.io\lib\manager.js:459:38)
    at WebSocket.onMessage (C:\Personal\software\nodejs\NODE\node_modules\socket
.io\lib\transport.js:387:20)
    at Parser.<anonymous> (C:\Personal\software\nodejs\NODE\node_modules\socket.
io\lib\transports\websocket\hybi-16.js:40:10)
    at Parser.emit (events.js:67:17)
    at C:\Personal\software\nodejs\NODE\node_modules\socket.io\lib\transports\we
bsocket\hybi-16.js:286:16
    at Parser.expectHandler (C:\Personal\software\nodejs\NODE\node_modules\socke
t.io\lib\transports\websocket\hybi-16.js:297:15)

我正在使用 redis pubsub,当我订阅 redis 时,它会抛出此警告。

【问题讨论】:

    标签: node.js redis socket.io


    【解决方案1】:

    有一个与此相关的已知问题。好像几个月前打过补丁。最简单的解决方法是将最大侦听器设置为 0,这将消除实际限制。所以它看起来像这样:

    this.sub = redis.createClient(opts.redisSub.port, opts.redisSub.host, opts.redisSub);
    this.sub.setMaxListeners(0);
    

    你可以在这里找到完整的讨论:https://github.com/LearnBoost/socket.io/issues/520

    【讨论】:

    • 麦克谢谢。根据讨论,应该是this.sub.maxListeners(0),而不是this.sub.setMaxListeners(0);无论如何,让我试试,并会更新你。
    • 迈克,刚刚测试过。它应该是 setMaxListeners(0) 而不是 maxListeners(0)。似乎工作正常。谢谢。
    猜你喜欢
    • 2013-02-25
    • 1970-01-01
    • 2012-03-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-04-09
    • 2012-09-14
    • 2014-08-09
    相关资源
    最近更新 更多