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)

questionAnswers(7)

yourAnswerToTheQuestion