考虑这个示例脚本:
<?php $pipes = array(); $p = proc_open('cat', array(0 => STDIN, 1 => STDOUT, 2 => STDERR), $pipes); fgetc(STDIN);
当/bin/sh
被链接到/bin/dash
(Debian默认)时, cat
会在shell中执行:
30760 pts/0 S+ 0:00 | \_ php f.php 30761 pts/0 S+ 0:00 | \_ sh -c cat 30762 pts/0 S+ 0:00 | \_ cat
当/bin/sh
链接到/bin/bash
时, cat
是php
的直接子php
:
30786 pts/0 S+ 0:00 | \_ php f.php 30787 pts/0 S+ 0:00 | \_ cat
这是非常烦人的不一致,这使得不可能可靠地发送信号产生的过程(因为信号有时被壳接收)。
为什么proc_open的行为取决于/bin/sh
指向? 有没有办法不运行一个shell,即使/bin/sh
不是bash
?
PHP在两种情况下都通过/ bin / sh运行命令,区别在于shell,而不是PHP。 破折号分叉进程运行命令(在这种情况下,猫),并等待它完成。 bash执行一个execve(),所以它用cat替换它自己的进程。
他们似乎已经修复它在以后的版本: https : //bugs.debian.org/cgi-bin/bugreport.cgi? bug = 436666
使用bash或破折号的最新版本应该解决您的问题,因为执行的命令获取衍生shell的PID,从而接收信号。