如何在 SIGINT 上停止 node.js 检查器/Chrome 调试器?
How to stop the node.js inspector / Chrome Debugger on SIGINT?
我有以下代码从终端捕获 ^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。
好像是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)
我从 nodemon 遇到了同样的终端错误,即使我认为我会退出所有终端进程,但简单地退出 VSCode 并重新打开就解决了(感谢 的提示).
希望这对其他人也有帮助!
在节点 docker。使用 ss
,完成,如果您知道端口已打开:
kill `ss -lptn 'sport = :THE_PORT' | tail -n1 | cut -d, -f2 | cut -d= -f2`
杀死所有节点进程
taskkill /im node.exe
or forcefully
taskkill /f /im node.exe
这对我有用:
fuser -k -n tcp 9229
我注意到,如果您使用 yarn dev
启动脚本,则 yarn 将 运行 一个单独的调试节点进程,该进程将占用第一个端口,然后如果调试器宽松,它将尝试下一个端口和 boom 你有 2 个端口 9229,然后是下一个 9230。
所以解决方案是直接实际调用脚本,以便节点调试实际脚本并分配您期望的端口。
例如:如果我的 package.json 在其脚本部分有 "dev": "app develop"
,而我通常 运行 在命令行上使用 yarn dev
。执行 NODE_OPTIONS=--inspect yarn dev
将导致此问题。解决方案是 运行 NODE_OPTIONS=--inspect app develop
,这会调用 yarn 在脚本中要执行的操作。
我有以下代码从终端捕获 ^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。
好像是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)
我从 nodemon 遇到了同样的终端错误,即使我认为我会退出所有终端进程,但简单地退出 VSCode 并重新打开就解决了(感谢
希望这对其他人也有帮助!
在节点 docker。使用 ss
,完成,如果您知道端口已打开:
kill `ss -lptn 'sport = :THE_PORT' | tail -n1 | cut -d, -f2 | cut -d= -f2`
杀死所有节点进程
taskkill /im node.exe
or forcefully
taskkill /f /im node.exe
这对我有用:
fuser -k -n tcp 9229
我注意到,如果您使用 yarn dev
启动脚本,则 yarn 将 运行 一个单独的调试节点进程,该进程将占用第一个端口,然后如果调试器宽松,它将尝试下一个端口和 boom 你有 2 个端口 9229,然后是下一个 9230。
所以解决方案是直接实际调用脚本,以便节点调试实际脚本并分配您期望的端口。
例如:如果我的 package.json 在其脚本部分有 "dev": "app develop"
,而我通常 运行 在命令行上使用 yarn dev
。执行 NODE_OPTIONS=--inspect yarn dev
将导致此问题。解决方案是 运行 NODE_OPTIONS=--inspect app develop
,这会调用 yarn 在脚本中要执行的操作。