2

我正在尝试为测试目的创建一个本地 API 服务,这涉及在我的构建系统中运行 make 命令。代码如下所示:

(注意:这是在咖啡脚本中)

request = require "request"
child_process = require "child_process"
tsc = require "training_service_connector"

campaign = "happytest"
strategy = campaign
port_number = 54340
service_conf_filename = tsc.writeServiceConfig(strategy, port_number)
exec_callback = (error, stdout, stderr) -> 
    console.log ('stdout:\n' + stdout + '\nstderr:\n' + stderr + "\nerror:\n" + error)
child_process.exec ("CONFIG=#{service_conf_filename} make run_bidder_service_runner", exec_callback)

# some other stuff

现在,为了弄清楚在 API 启动后如何让测试的其余部分运行(呃异步),我一直在 REPL 中运行这段代码。REPL 是错误的,所以我必须使用 ctrl+Z 来杀死它。杀死进程后,似乎子进程仍在运行......

lsof -i :54340
COMMAND   PID USER   FD   TYPE   DEVICE SIZE/OFF NODE NAME
python  52650  max    3u  IPv4 20606263      0t0  TCP localhost:54340 (LISTEN)

现在,如果我再次尝试运行它,我会收到一条错误消息,指出该端口已在使用中。为什么子进程不会与父进程一起死亡?

4

1 回答 1

3

不同的操作系统以不同的方式处理子进程。我通常像这样添加处理程序:

['SIGINT', 'SIGHUP', 'SIGTERM'].forEach(function(signal) {
    process.addListener(signal, gracefulShutdown);
});

gracefulShutdown应该做诸如关闭套接字和退出进程(process.stop())之类的事情

哦......我只是重读了你的问题。ctrl-z 暂停一个进程,它不会杀死它。如果您使用fgor bg,它会将进程带回前台/后台。要快速 REPL,请使用 ctrl-c 两次。

于 2013-10-29T20:42:10.313 回答