【问题标题】:How to stop the node.js inspector / Chrome Debugger on SIGINT?如何在 SIGINT 上停止 node.js 检查器/Chrome 调试器?
【发布时间】:2018-05-16 12:05:48
【问题描述】:

我有以下代码从终端捕获 ^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.

【问题讨论】:

标签: node.js express node-inspector


【解决方案1】:

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

$ ps ax | grep node

然后

$ killall -9 node

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

$ sudo ss -lptn 'sport = :9229'

$ sudo netstat -nlp | grep :9229

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

那么:

$ sudo kill <pid>

或者只是 [两步合二为一]

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

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

【讨论】:

    【解决方案2】:

    我在 nodemon 中遇到了同样的终端错误,即使我以为我会退出所有终端进程,但只需退出 VSCode 并重新打开就可以解决(感谢 KhogaEslam's answer 的提示)。

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

    【讨论】:

      【解决方案3】:

      在节点码头。用ss,完成,如果你知道端口是开放的:

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

      【讨论】:

      • 对其进行测试:超时 1 bash -c 'cat /dev/tcp/localhost/THE_PORT'
      【解决方案4】:

      杀死所有节点进程

      taskkill /im node.exe

      or forcefully
      

      taskkill /f /im node.exe

      【讨论】:

        【解决方案5】:

        这对我有用:

        fuser -k -n tcp 9229
        

        【讨论】:

          【解决方案6】:

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

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

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

          【讨论】:

            猜你喜欢
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 2013-11-06
            • 2017-03-11
            • 1970-01-01
            • 2016-07-02
            相关资源
            最近更新 更多