问题描述
Windows 10 x64
节点v12.19.0
为什么在浏览器中首次打开SIGTERM
后没有被称为我的http://localhost:3000/
事件的处理程序?我的处理程序没有执行就终止了应用程序(我看不到它的控制台输出)。
// node v12.19.0
const http = require("http");
const server = http.createServer((req,res)=> {
res.statusCode = 200;
res.end("Hello,World!");
setTimeout(() => { process.kill(process.pid,"SIGTERM"); },2000);
});
process.on("SIGTERM",() => { // Why it will not be executed?
process.statusCode = 1;
console.log("SIGTERM");
server.close(() => {
console.log("Process terminated.");
});
});
server.listen(3000,()=>{
console.log("Server works on http://localhost:3000/");
});
我的控制台输出(PowerShell):
PS C:\tmp_src> node index.js
Server works on http://localhost:3000/
PS C:\tmp_src>
解决方法
在Windows 10上,process.on('SIGINT',cb)
对我有用,可以在外壳程序中捕获 CTRL + C 之类的中断,或者在IDE中捕获停止按钮命令。 / p>
它在Linux上的生产中也很好用,特别是对于pm2 restart
和类似命令。