2016-08-17 48 views
0

我在新服務器上運行命令proc_open()時遇到問題。我創建了以下腳本測試:爲什麼proc_open()多次運行相同的命令?

$desc = array(
    0 => array('pipe', 'r'), // we use to write data 
    1 => array('pipe', 'w'), // we use to read data 
    2 => array('pipe', 'w') // errors' log 
); 

$cmd = "exec php -v"; 
$process = proc_open($cmd, $desc, $pipes); 

if (is_resource($process)) { 
    stream_set_blocking($pipes[1], 0); 
    stream_set_blocking($pipes[2], 0); 
    $cmd .= "\nMETA: " . print_r(stream_get_meta_data($pipes[1]), true); 

    if (is_resource($pipes[1])) { 
     $cmd .= "\nSTDOUT: " . stream_get_contents($pipes[1]); 
    } 

    if (is_resource($pipes[2])) { 
     $cmd .= "\nSTDERR: " . stream_get_contents($pipes[2]); 
    } 

    $status = proc_get_status($process); 
    $cmd .= "\n" . print_r($status, true); 
    proc_close($process); 
} else { 
    $cmd .= "\nFailed!"; 
} 

echo "<pre>{$cmd}</pre>"; 

腳本只是掛起並無法顯示輸出。看看控制檯,我發現腳本多次產生相同的命令。參見:

root[~]# clear && ps ax o pid,args | grep [p]hp 
10122 /usr/bin/php /home/user/public_html/thread.php 
10124 php -v 
10126 php -v 
10128 php -v 
10130 php -v 
10132 php -v 
10134 php -v 
10136 php -v 
10138 php -v 
10140 php -v 
10142 php -v 
10144 php -v 
10146 php -v 
10148 php -v 
10150 php -v 
10152 php -v 
10154 php -v 
10156 php -v 
10158 php -v 
10160 php -v 
10162 php -v 
10164 php -v 
10166 php -v 
10168 php -v 
10170 php -v 
10172 php -v 
10174 php -v 
10176 php -v 
10178 php -v 
10181 php -v 
10184 php -v 
10187 php -v 
10189 php -v 
10191 php -v 
10193 php -v 
10195 php -v 
10197 php -v 
10199 php -v 
10201 php -v 
10205 php -v 
10207 php -v 
10210 php -v 
10212 php -v 
10214 php -v 
10216 php -v 
10219 php -v 
10222 php -v 
10224 php -v 
10226 php -v 
10229 php -v 
10231 php -v 
10233 php -v 
10235 php -v 
10237 php -v 
10239 php -v 
10242 php -v 
10245 php -v 
10248 php -v 
10250 php -v 
10252 php -v 
10254 php -v 
10256 php -v 
10258 php -v 
10260 php -v 
10262 php -v 
10264 php -v 
10266 php -v 
10268 php -v 
10270 php -v 
10272 php -v 
10274 php -v 
10276 php -v 
10279 php -v 
10282 php -v 
10284 php -v 
10287 php -v 
10289 php -v 
10291 php -v 
10293 php -v 
10295 php -v 
10297 php -v 
10299 php -v 
10301 php -v 
10303 php -v 
10305 php -v 
10307 php -v 
10309 php -v 
10311 php -v 
10313 php -v 
10315 php -v 
10317 php -v 
10319 php -v 
10321 php -v 
10323 php -v 
10325 php -v 
10327 php -v 
10329 php -v 

但是,相同的腳本在我的本地機器(Win10)上工作。我已經搜索了這個問題,但沒有在其他地方找到它。

與服務器環境或PHP安裝有關嗎?

+0

你想完成什麼?你爲什麼要調用'exec'? – miken32

+0

實際上,我想在外部進程上運行PHP腳本。原因是因爲我編寫了一個名爲'Thread'的類。此類旨在在單獨的進程上運行(異步)。所以我做的是啓動一個新的shell並在後臺執行PHP腳本。這個解決方案在其他平臺上已經可以正常工作,但現在我開始面對這個問題。 –

+0

關於'exec',沒有它,代碼片段就可以正常工作。但在我真正的實現中,我必須把它(不要記得爲什麼,因爲代碼有點舊)。但是如果我沒有錯,就不要爲真正的命令獲得一個子shell。 –

回答

0

我不知道爲什麼,但將PHP處理程序從suphp更改爲cgi就解決了這個問題。現在腳本按預期行事。

如果有人能解釋爲什麼,會受到歡迎。

相關問題