如何在SIGINT上停止node.js检查器/ Chrome调试器?

时间:2017-12-02 15:24:46

标签: node.js express node-inspector

我有以下代码从终端捕获^ C并正常关闭我的Express应用程序:

process.on('SIGINT', () => {
    console.log('SIGINT received ...');
    console.log('Shutting down the server');

    server.close(() => {
        console.log('Server has been shutdown');
        console.log('Exiting process ...');
        process.exit(0);
    });
});

但是,如果我使用--inspect启动节点实例,则上述代码无法停止检查器和Chrome调试器。当我重新启动我的应用程序时,出现以下错误:

Starting inspector on 127.0.0.1:9229 failed: address already in use

如何优雅地停止我的应用以避免此错误?

完整代码here

6 个答案:

答案 0 :(得分:17)

似乎VSCode,Puppeteer,nodemon,express等导致了这个问题, 你在后台运行了一个进程,或者只是关闭了调试区[浏览器,终端等]或其他什么, 无论如何,你可以在CMD中运行

$ ps ax | grep node

然后

$ killall -9 node

这不是最好的解决方案,我也建议您使用此端口查找进程然后发送关闭信号

$ sudo ss -lptn 'sport = :9229'

OR

$ sudo netstat -nlp | grep :9229

OR

$ sudo lsof -n -i :9229 | grep LISTEN
那天:

$ sudo kill <pid>

或者只是[两个步骤合二]

$ sudo kill `sudo lsof -t -i:9229`

OR

$ sudo kill $(sudo lsof -t -i:9229)

答案 1 :(得分:2)

杀死所有节点进程

taskkill / im node.exe

var cleave = new Cleave('.loan_max_amount', {
    numeral: true,
    numeralThousandsGroupStyle: 'thousand'
});

taskkill / f / im node.exe

答案 2 :(得分:2)

这对我有用:

fuser -k -n tcp 9229

答案 3 :(得分:1)

即使我以为我会退出所有终端进程,我也遇到了来自nodemon的同样的终端错误,但只是退出了VSCode并为我重新打开(感谢KhogaEslam's answer的提示)。

希望这对其他人也有帮助!

答案 4 :(得分:0)

在节点docker上。如果您知道端口已打开,请使用ss完成:

kill `ss -lptn 'sport = :THE_PORT' | tail -n1 | cut -d, -f2 | cut -d= -f2`

答案 5 :(得分:0)

我注意到,如果您使用 yarn dev 启动脚本,则纱线将运行一个单独的调试节点进程,该进程将采用第一个端口,然后如果调试器宽松,它将尝试下一个端口并繁荣您有 2 个端口 9229,然后是下一个 9230。

所以解决方案是直接实际调用脚本,以便节点调试实际脚本并分配您期望的端口。

例如:如果我的 package.json 在其脚本部分有 "dev": "app develop" 并且我通常在命令行上使用 yarn dev 运行它。执行 NODE_OPTIONS=--inspect yarn dev 会导致此问题。解决方案是运行 NODE_OPTIONS=--inspect app develop,这会调用 yarn 将在脚本中执行的操作。