socket.io redis和内存泄漏

我的socket.io版本是[email protected]和[email protected]。 我在Windows上。socket.io redis和内存泄漏

在某些地方,我看到问题已解决。我想我正在使用最新的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

以上是 socket.io redis和内存泄漏 的全部内容, 来源链接: utcz.com/qa/257943.html

回到顶部