PHP proc_open bash vs dash

时间:2014-03-25 19:19:52

标签: php linux proc-open

考虑这个示例脚本:

<?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相关联时,catphp的直接子女:

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

1 个答案:

答案 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,从而接收信号。