Odpowiedzi:
node-memwatch : wykrywa i znajduje wycieki pamięci w kodzie Node.JS. Sprawdź ten samouczek Śledzenie wycieków pamięci w Node.js.
Wbudowany moduł procesu ma metodę, memoryUsagektóra zapewnia wgląd w wykorzystanie pamięci przez bieżący proces Node.js. Oto przykład z Node v0.12.2 w systemie 64-bitowym:
$ node --expose-gc
> process.memoryUsage(); // Initial usage
{ rss: 19853312, heapTotal: 9751808, heapUsed: 4535648 }
> gc(); // Force a GC for the baseline.
undefined
> process.memoryUsage(); // Baseline memory usage.
{ rss: 22269952, heapTotal: 11803648, heapUsed: 4530208 }
> var a = new Array(1e7); // Allocate memory for 10m items in an array
undefined
> process.memoryUsage(); // Memory after allocating so many items
{ rss: 102535168, heapTotal: 91823104, heapUsed: 85246576 }
> a = null; // Allow the array to be garbage-collected
null
> gc(); // Force GC (requires node --expose-gc)
undefined
> process.memoryUsage(); // Memory usage after GC
{ rss: 23293952, heapTotal: 11803648, heapUsed: 4528072 }
> process.memoryUsage(); // Memory usage after idling
{ rss: 23293952, heapTotal: 11803648, heapUsed: 4753376 }
W tym prostym przykładzie widać, że przydzielenie tablicy 10 mln elementów konsumenci wynosi około 80 MB (spójrz na heapUsed).
Jeśli spojrzeć na kod źródłowy V8 ( Array::New, Heap::AllocateRawFixedArray, FixedArray::SizeFor), to zobaczysz, że pamięć używana przez tablicy jest wartością stałą plus długość pomnożona przez wielkość wskaźnika. Ta ostatnia zajmuje 8 bajtów w systemie 64-bitowym, co potwierdza, że zaobserwowana różnica pamięci wynosząca 8 x 10 = 80 MB ma sens.
--expose-gctej gcfunkcji?
--expose-gcza process.memoryUsage(). gc()(require --expose-gc) został użyty w odpowiedzi do deterministycznego wyzwalania czyszczenia pamięci, aby łatwiej było zobaczyć, jakie process.memoryUsageraporty.
Ponadto, jeśli chcesz poznać pamięć globalną, a nie proces węzłowy:
var os = require('os');
os.freemem();
os.totalmem();
Oryginalny memwatch jest zasadniczo martwy. Zamiast tego wypróbuj memwatch-next , który wydaje się działać dobrze w nowoczesnych wersjach Node.
W systemie Linux / Unix (uwaga: Mac OS to Unix) użyj topi naciśnij M ( Shift+M ), aby posortować procesy według użycia pamięci.
W systemie Windows użyj Menedżera zadań.
Applications > Utilitiesa znajdziesz Activity Monitoraplikację. Ten jest odpowiednikiem Menedżera zadań. OS X również ma toppolecenie.
htopzamiast góry w systemie Linux. Jest dużo lepiej.