最小复现代码:
test.js
function sleep(delay) { return new Promise(resolve => setTimeout(resolve, delay)); }const _ = require('lodash');async function doTask() { // console.log('start'); await sleep(_.random(10, 30)); // console.log('done');}async function start() { await sleep(3); await doTask(); await start(); // 去掉前面的await就好了} start(); setInterval(() => { console.log(process.memoryUsage()); },10e3);
进程启动的时候rss是22M,运行了1个多小时后内存占用达到了380M
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 30211 devel 20 0 1229m 381m 10m S 1.0 9.6 1:36.63 node test.js# 在start函数的递归调用中取消await21729 devel 20 0 867m 23m 10m S 1.0 0.6 1:22.73 node test.js# 改成循环14498 devel 20 0 867m 24m 10m S 1.0 0.6 1:11.04 node test.js
虽然确定是在递归调用的时候前面多加了个await,但是能解释下原因么,是我使用的姿势不对么
慕沐林林
相关分类