阿神2017-05-16 13:31:53
執行檔的時候,使用
node --inspect --expose-gc XXX.js
這裡面兩個兩個 flag --inspact 是告訴它透過chrome devtool 進行調試,--expose-gc 是說你可以透過global.gc()
方法主動收集記憶體。
執行之後就會有一個chrome://
协议的链接,粘贴进chrome,就会出现最常见的chrome dev tool,在profile 里面,点击第二栏 Take Heap Snapshot,然后点击Take Snapshot,记录一次当前heap
内存使用情况,此时就会出现当前的内存使用情况的快照,然后等一下,让node程序运行一段时间,再记录一次,然后点击左上角的Summary
切换成Comparison
模式,透過與第一次的對比,找到究竟是什麼增加了,就能找到具體的問題。
其次,可以在可疑的程式碼段前後通過 node
全局变量 process
的 memoryUsage
方法,打印出 heap
究竟的使用量,通过对比代码前后使用量的差别,判断是否有 heap
的洩漏。
透過題主的報錯訊息,像是 express session 記錄時的問題,在寫 session 的地方多打斷點,透過 process.memoryUsage()
方法看看究竟是哪裡出了問題,這個需要耐心和運氣。