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

在某些地方,我已经看到问题已经解决。我想我正在使用最新的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时,那时它会引发此警告。

有帮助吗?

解决方案

与此相关的已知问题。看起来它是几个月前修补的。最简单的修复是将最大侦听器设置为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

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top