我有以下代码:PHP流程执行超时
/**
* Executes a program and waits for it to finish, taking pipes into account.
* @param string $cmd Command line to execute, including any arguments.
* @param string $input Data for standard input.
* @param integer $timeout How much to wait from program in msecs (-1 to wait indefinitely).
* @return array Array of "stdout", "stderr" and "return".
*/
function execute($cmd,$stdin=null,$timeout=-1){
$proc=proc_open(
$cmd,
array(array('pipe','r'),array('pipe','w'),array('pipe','w')),
$pipes=null
);
fwrite($pipes[0],$stdin); fclose($pipes[0]);
$stdout=stream_get_contents($pipes[1]); fclose($pipes[1]);
$stderr=stream_get_contents($pipes[2]); fclose($pipes[2]);
$return=proc_close($proc);
return array(
'stdout' => $stdout,
'stderr' => $stderr,
'return' => $return
);
}
它有两个 “问题”。
- 该代码是同步的;它会冻结,直到目标进程关闭。
- 到目前为止,我还没有,而不会发出不同类型的命令能够从“冻结”(如
$cmd > /dev/null &
在Linux和start /B $cmd
在Windows上)
我不介意“冻结“,完全可以。我只需要实现那个超时。
注意:该解决方案跨平台兼容非常重要。 $cmd
不必更改也很重要 - 我运行的是一些复杂的命令,但恐怕可能会出现一些问题,但这取决于修复的类型 - 我很高兴听到这些信息,只是我更喜欢不同的选择。
我发现一些资源,可以帮助:
- Run perl file from PHP script but not wait for output on Windows Server
- PHP set timeout for script with system call, set_time_limit not working
- http://www.shapeshifter.se/2008/08/04/asynchronous-background-execution-with-php/