大佬教程收集整理的这篇文章主要介绍了在linux中使用PHP的posix_kill()会导致奇怪的行为,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
停止是有问题的地方.单击停止按钮后,随机发生两件事之一.有一个浏览器错误页面(101连接重置或324空响应)或页面加载两次,但您只能第二次看到它.我知道它加载两次的原因是因为代码中的调试消息.在这两种情况下,启动程序进程都被终止(发送SIGTERM).但是如果页面加载两次,则第一次杀死启动器(此部分的页面上没有任何内容),第二次检查并发现没有启动器进程正在运行并显示一条消息:“启动器未运行”.
我正在将调试消息写入文件,发现重新加载发生在PHP代码中的某个变量行(有时会打印某个调试消息,有时则不会打印.)此外,PHP错误报告设置为ALL没有错误.
Launcher捕获SIGTERM,依次将SIGTERM发送到它的子进程,然后调用exit(0).
有趣的是,如果SIGKILL用于杀死启动器,那么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()会导致奇怪的行为所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。