我的socket.io版本是socket.io@0.8.7和redis@0.7.1。我在Windows上。
在某些地方,我已经看到问题已解决。我想我正在使用最新的socket.io版本。什么是generator.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