posixkill php,在linux中使用PHP的posix_kill()会导致奇怪的行为

我正在创建一个网页,用于监视和控制一些自定义C程序.我创建了一个页面,它将启动/停止一个C程序’启动器'(漂亮的通用名称),然后分叉并创建许多子进程.开始工作正常 – exec(“cd launcher_dir; nohup ./launcher> outfile 2>& 1&”);

停止是有问题的地方.单击停止按钮后,随机发生两件事之一.有一个浏览器错误页面(101连接重置或324空响应)或页面加载两次,但您只能第二次看到它.我知道它加载两次的原因是因为代码中的调试消息.在这两种情况下,启动程序进程都被终止(发送SIGTERM).但是如果页面加载两次,则第一次杀死启动器(此部分的页面上没有任何内容),第二次检查并发现没有启动器进程正在运行并显示一条消息:“启动器未运行”.

我正在将调试消息写入文件,发现重新加载发生在PHP代码中的某个变量行(有时会打印某个调试消息,有时则不会打印.)此外,PHP错误报告设置为ALL没有错误.

Launcher捕获SIGTERM,依次将SIGTERM发送到它的子进程,然后调用exit(0).

有趣的是,如果SIGKILL用于杀死启动器,那么PHP工作正常并且符合预期,但是这不允许启动器很好地关闭.这可能发生什么?

这是相关的PHP代码:

function stop_launcher(){

$pid = get_launcher_pid(); // Definitely returns the correct pid

debug_message("stop_launcher called,pid = ".$pid);

if ($pid == "") {

// If no 'connection reset' error occurs this is displayed

// after first executing the else branch. Why is the PHP being run twice?

print "Launcher doesn't seem to be running..
";

exit;

} else {

debug_message("killing");

posix_kill(intval($pid),15); //SIGTERM

debug_message("kill finished"); // Sometimes this message is written,sometimes not

if (ps_exists($pid)) { // Definitely works. This never gets displayed

print "Shutdown Failed. Try again";

exit;

}

}

}

function debug_message($message){

$fh = fopen(".debug",'a') or die("can't open file");

fwrite($fh,date("-r").": ".$message."\n");

fclose($fh);

}

任何建议表示赞赏!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值