web-dev-qa-db-ja.com

node.jsインスペクターを停止する方法/ Chrome 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

このエラーを回避するには、アプリを正常に停止するにはどうすればよいですか?

完全なコードが利用可能 こちら

9
Naresh

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>

OR JUST [1つの2つのステップ]

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

OR

$ Sudo kill $(Sudo lsof -t -i:9229)
21
KhogaEslam

すべてのターミナルプロセスを終了すると思っていたにもかかわらず、nodemonから同じターミナルエラーが発生しましたが、VSCodeを終了して再開するだけで解決しました(ヒントについては KhogaEslamの回答 に感謝します)。

これが他の誰かにも役立つことを願っています!

2
Joel Balmer

ノードドッカーにありました。ポートが開いていることがわかっている場合は、ssで完了します。

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