鍍金池/ 問答/PHP/ 對于PHP中的shell_exec()函數(shù)執(zhí)行過程的疑問?

對于PHP中的shell_exec()函數(shù)執(zhí)行過程的疑問?

我的loopBuy.php代碼如下:

<?php
$start_time = microtime();

for ($i = 0; $i < 10; ++$i) {
    shell_exec('php buy_mysql.php');
}

$end_time = microtime();

echo $end_time - $start_time;

我的buy_mysql.php代碼如下:

<?php
    

    $url = 'http://localhost/Seckill/index.php?app=app&c=seckill&a=addQsec&gid=2&type=mysql';
    $result = file_get_contents($url);
    
    var_dump($result);

buy_mysql.php這個腳本就是對數(shù)據(jù)庫進行操作:把某條記錄的一個字段減去1:
圖片描述

當(dāng)我去執(zhí)行loopBuy.php腳本的時候,得到如下結(jié)果:
圖片描述
也就是一個負數(shù)的時間差?而且這個loopBuy.php腳本在執(zhí)行的時候,我默數(shù)了一下大概有10秒。

然后我修改loopBuy.php腳本的代碼:

<?php
$start_time = microtime();

for ($i = 0; $i < 10; ++$i) {
    $a = 1;
}

$end_time = microtime();

echo $end_time - $start_time;

得到的結(jié)果比較正常:

圖片描述

所以我覺得問題是出在了shell_exec()這個函數(shù)的原理上面。
其實我是頭腦發(fā)熱了一下。本來應(yīng)該先fork出一個子進程,然后再來執(zhí)行shell_exec()函數(shù)。但是我驚奇的發(fā)現(xiàn),執(zhí)行shell_exec()函數(shù)貌似沒有完全替換掉原來進程的頁表,因為shell_exec()后面的代碼依然可以執(zhí)行。
然后我用C語言寫了一個類似的代碼:

#include <stdio.h>
#include<unistd.h>

int main(int argc, char const *argv[]) {
    execlp("ls", "ls", NULL);

    printf("here\n");
    
    return 0;
}

得到的結(jié)果是:
圖片描述

這個程序并沒有打印出字符串here,說明在C語言里面,這個實現(xiàn)是替換了原來進程的頁表。
所以回到原來的問題,我感覺是因為在PHP函數(shù)里面,·shell_exec()·的實現(xiàn)導(dǎo)致了上面那樣奇怪的現(xiàn)象。
希望前輩能夠指點一下,謝謝?。?/p>

回答
編輯回答
浪蕩不羈

不懂 php ,但是這種問題,直接找到代碼看不就好了么: https://github.com/php/php-sr...

2017年7月20日 09:53
編輯回答
清夢

時間差為負數(shù)的原因已經(jīng)解決了,是我對這個函數(shù)不熟悉,沒有加參數(shù)true。

2017年8月9日 22:47