我正在编写一个Perl脚本,它将编写一些输入并将这些输入发送到外部程序.这个程序有一个很小但非零的机会,我想把它计时:
my $pid = fork;
if ($pid > 0){
eval{
local $SIG{ALRM} = sub { die "TIMEOUT!"};
alarm $num_secs_to_timeout;
waitpid($pid, 0);
alarm 0;
};
}
elsif ($pid == 0){
exec('echo blahblah | program_of_interest');
exit(0);
}
Run Code Online (Sandbox Code Playgroud)
现在,在$ num_secs_to_timeout之后,program_of_interest仍然存在.我试图在匿名子程序中杀死它,$SIG{ALRM}如下所示:
local $SIG{ALRM} = sub{kill 9, $pid; die "TIMEOUT!"}
Run Code Online (Sandbox Code Playgroud)
但这没有做任何事情.program_of_interest仍然存在.我如何杀死这个过程?
我能够通过杀死进程组来成功杀死我的exec()ed进程,如在perl中回答问题所示,当使用open创建子进程时杀死子进程及其子进程.我修改了我的代码如下:
my $pid = fork;
if ($pid > 0){
eval{
local $SIG{ALRM} = sub {kill 9, -$PID; die "TIMEOUT!"};
alarm $num_secs_to_timeout;
waitpid($pid, 0);
alarm 0;
};
}
elsif ($pid == 0){
setpgrp(0,0);
exec('echo blahblah | program_of_interest');
exit(0);
}
Run Code Online (Sandbox Code Playgroud)
超时后,program_of_interest被成功杀死.
| 归档时间: |
|
| 查看次数: |
12066 次 |
| 最近记录: |