如何在 SIGINT 上停止 node.js 检查器/Chrome 调试器?
Posted
技术标签:
【中文标题】如何在 SIGINT 上停止 node.js 检查器/Chrome 调试器?【英文标题】:How to stop the node.js inspector / Chrome Debugger on SIGINT? 【发布时间】: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.
【问题讨论】:
嘿,你找到解决办法了吗? 不,仍然是个问题。 Error: That port is already in use.的可能重复 【参考方案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
,这会调用纱线将在脚本中执行的操作。
【讨论】:
以上是关于如何在 SIGINT 上停止 node.js 检查器/Chrome 调试器?的主要内容,如果未能解决你的问题,请参考以下文章
如何在 node.js express 中的路由 end() 之后停止中间件序列继续进行