端末から^ 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
このエラーを回避するには、アプリを正常に停止するにはどうすればよいですか?
完全なコードが利用可能 こちら 。
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)
すべてのターミナルプロセスを終了すると思っていたにもかかわらず、nodemonから同じターミナルエラーが発生しましたが、VSCodeを終了して再開するだけで解決しました(ヒントについては KhogaEslamの回答 に感謝します)。
これが他の誰かにも役立つことを願っています!
ノードドッカーにありました。ポートが開いていることがわかっている場合は、ss
で完了します。
kill `ss -lptn 'sport = :THE_PORT' | tail -n1 | cut -d, -f2 | cut -d= -f2`