NodeJS: Jak debugować „Wykryto wyciek pamięci EventEmitter. Dodano 11 słuchaczy ”
Jak mogę debugować moją aplikację, która rzuca ten błąd:
(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:653:33)
at Socket.EventEmitter.once (events.js:179:8)
at TCP.onread (net.js:527:26)
Nie mogłem znaleźć zakładanego przeciekającego obiektu dla zwiększenia limitu nasłuchiwania o.setMaxListeners(0);
ROZWIĄZANIE (od fardjad i jan salawa)
Z wyszukiwaniem jana salawy znalazłem działającą bibliotekę (długi John) dla zwiększenia ilości śladów stosu. Dzięki odpowiedzi fardjada odkryłem, że musimy prototypowaćEventEmitter.addListener
I EventEmitter.on
.
Dzięki rozwiązaniu mogłem uzyskać ten nowy ślad:
(node) warning: possible EventEmitter memory leak detected. 11 listeners added. Use emitter.setMaxListeners() to increase limit.
Trace
at EventEmitter.addListener.EventEmitter.on (xxx/main.js:44:15)
at Readable.on (_stream_readable.js:653:33)
at ServerResponse.assignSocket (http.js:1072:10)
at parser.onIncoming (http.js:1979:11)
at parserOnHeadersComplete (http.js:119:23)
at socket.ondata (http.js:1912:22)
at TCP.onread (net.js:510:27)