如果脚本被杀死,node.js 生成的进程仍然存在

标签 node.js spawn child-process

是否可以确保使用 node.js child_process 生成的进程将在父进程被杀死时被杀死?

这是一个示例脚本

var spawn = require('child_process').spawn;
var log_tail = spawn("tail", ["-f", "/dev/null"]);

setInterval(function() {
  console.log('just chilling');
}, 10000);

如果我查看进程树,我会看到:

$ ps faux
ubuntu    9788  0.0  0.0  73352  1840 ?        S    15:04   0:00  |   \_ sshd: ubuntu@pts/7  
ubuntu    9789  0.0  0.2  25400  6804 pts/7    Ss   15:04   0:00  |       \_ -bash
ubuntu   10149  1.0  0.2 655636  8696 pts/7    Sl+  15:07   0:00  |           \_ node test.js
ubuntu   10151  0.0  0.0   7184   608 pts/7    S+   15:07   0:00  |               \_ tail -f /dev/null

然后我需要停止该脚本并且不能按 ctrl-c(假设我的 ssh 连接丢失)

$ kill 10149
$ ps faux
ubuntu   10151  0.0  0.0   7184   608 pts/7    S    15:07   0:00 tail -f /dev/null

您可以看到尾部进程仍在运行,并且已与任何父进程分离。

如果生成器被杀死,是否有编程方法来杀死生成的进程?

是否有可以传递给 spawn 的选项,或者我应该使用不同的方法,还是需要捕获 kill 信号(这对 kill -9 有效)?

最佳答案

对劳动力不太友好,但这是我使用的模板:

var spawn = require("child_process").spawn;
var workers = [];

var killWorkers = function() {
  workers.forEach(function(worker) {
    process.kill(worker);
  });
});

process.on("uncaughtException", killWorkers);
process.on("SIGINT", killWorkers);
process.on("SIGTERM", killWorkers);

var new_worker = spawn("tail", ["-f", "/dev/null"]);
workers.push(new_worker);

我主要使用它来在主进程死亡时杀死集群中的工作人员。 Ed:显然,您可以从任何地方调用 killWorkers,而不仅仅是崩溃或中断。

关于如果脚本被杀死,node.js 生成的进程仍然存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11892028/

相关文章:

java - Node.js:如何写入 java-childprocess-stdin

即使在关闭其输入后,子进程也会挂起

javascript - Nodejs nohup 死机无一异常(exception)

java - 在 Maven 插件中设置 fork 和 spawn

go - scanner.Scan() 在 Linux 但不是 Windows 上阻塞直到退出

python - 如何在twisted python中获取spawn进程的状态?

node.js - Nodejs 向客户端生成远程 tail 和 socket-io

javascript - 使用 mongoose 对子文档数组进行复杂添加

javascript - Node 进程结束后Grunt(keep-alive)不退出

javascript - 等待请求完成并返回数据