背景:
日常进行CI过程中,使用NodeJs方式:GIT更新->检测是否需要编译->调用IncrediBuilder编译->读取编译日志判断是否通过->调用7z打包
问题:
持续进行一天(约18)小时候,会报错:JavaScript heap out of memory
尝试方式:
1、使用 --max-memory-restart
cmd /c pm2 start demo.js --max-memory-restart 4096M
2、启动检测批处理,并定时杀死NodeJs进程
:nexttasklist|find /i "node.exe" && (goto save)echo %date%%time%"重启"pm2 resurrectecho %date%%time%"等待10分钟"ping 127.0.0.1 -n 600 >1.txtdel 1.txt:saveecho %date%%time%"正常"pm2 saveping 127.0.0.1 -n 600 >1.txtdel 1.txtgoto next
taskkill /F /IM node.exe
注意事项:
1、出现:connect EPERM //./pipe/rpc.sock,解决方案:杀死进程,删除pm2.log 重启pm2