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

在linux中使用PHP的posix_kill()会导致奇怪的行为,第1张

概述我正在创建一个网页,用于监视和控制一些自定义C程序.我创建了一个页面,它将启动/停止一个C程序’启动器'(漂亮的通用名称),然后分叉并创建许多子进程.开始工作正常 – exec(“cd launcher_dir; nohup ./launcher> outfile 2>& 1&”); 停止是有问题的地方.单击停止按钮后,随机发生两件事之一.有一个浏览器错误页面(101连接重置或324空响应)或页面 我正在创建一个网页,用于监视和控制一些自定义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.. <br />";        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</br>";            exit;        }     }}function deBUG_message($message){    $fh = fopen(".deBUG",'a') or dIE("can't open file");    fwrite($fh,date("-r").":  ".$message."\n");    fclose($fh);}

任何建议表示赞赏!

解决方法 事实证明,这是让你觉得愚蠢的错误之一!发射器程序意外杀死了它的进程组…… 总结

以上是内存溢出为你收集整理的在linux中使用PHP的posix_kill()会导致奇怪的行为全部内容,希望文章能够帮你解决在linux中使用PHP的posix_kill()会导致奇怪的行为所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/1017465.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-23
下一篇 2022-05-23

发表评论

登录后才能评论

评论列表(0条)

保存