考虑这个示例脚本:
<?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
的直接子女:
30786 pts/0 S+ 0:00 | \_ php f.php
30787 pts/0 S+ 0:00 | \_ cat
这是非常恼人的不一致,这使得无法可靠地发送信号产生的进程(因为信号有时被shell接收)。
为什么proc_open的行为会有所不同,具体取决于/bin/sh
指向的位置?
有没有办法不运行shell,即使/bin/sh
不是bash
?
答案 0 :(得分:3)
PHP在两种情况下都通过/ bin / sh运行命令,不同之处在于shell,而不是PHP。 dash分叉进程运行命令(在本例中为cat)并等待它完成。 bash执行了一个execve(),所以它用cat替换了自己的进程。
他们似乎已在以后的版本中修复了它:https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=436466
使用bash或最新版本的破折号可以解决您的问题,因为执行的命令会获取生成的shell的PID,从而接收信号。