php如何實現並行

2020-10-10 12:01:13

php實現並行的方法:首先寫好針對第三方的請求介面;然後使用並行請求這些第三方的介面,並行程式碼如「function request(){...}」;最後使用php實現迴圈請求介面即可。

推薦:《》

php實現並行

使用場景

如果你第三方的多個介面,需要回圈請求,這時候就需要並行處理,因為 php 是單程序,順序執行的程式,如果有一個介面掛了,那麼後面的介面也不能得到請求,或者某個介面等待時間過長,下面的介面也需要等待時間,那麼十多個介面每個介面等待1S,十個介面就需要10S才能完成一次請求。這時候,就需要使用並行請求

使用方案

可以先寫好針對某個第三方的請求介面,然後使用並行請求這些第三方的介面

並行程式碼

function request(){
$srart_time = microtime(TRUE);
$webSiteUrl = 'http://test/';
/**
 * 結算
 */
$alls = [
    $webSiteUrl . "1.php",
    $webSiteUrl . "2.php",
];
//1 建立批次處理cURL控制程式碼
$chHandle = curl_multi_init();
$chArr = [];
//2.建立多個cURL資源
foreach ($alls as $Url) {
    $chArr[$Url] = curl_init();
    curl_setopt($chArr[$Url], CURLOPT_URL, $Url);
    curl_setopt($chArr[$Url], CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($chArr[$Url], CURLOPT_TIMEOUT, 1);
    curl_multi_add_handle($chHandle, $chArr[$Url]); //2 增加控制程式碼
}
$active = null;
/**常數
 * CURLM_CALL_MULTI_PERFORM==-1
 * // CURLM_OK == 0
 **/
do {
    $mrc = curl_multi_exec($chHandle, $active); //3 執行批次處理控制程式碼
} while ($mrc == CURLM_CALL_MULTI_PERFORM); //4
//4 $active 為true,即$chHandle批次處理之中還有$ch控制程式碼正待處理,$mrc==CURLM_OK,即上一次$ch控制程式碼的讀取或寫入已經執行完畢。
while ($active && $mrc == CURLM_OK) {
    if (curl_multi_select($chHandle) != CURLM_CALL_MULTI_PERFORM) {//$chHandle批次處理中還有可執行的$ch控制程式碼,curl_multi_select($chHandle) != -1程式退出阻塞狀態。
        do {
            $mrc = curl_multi_exec($chHandle, $active);//繼續執行需要處理的$ch控制程式碼。
        } while ($mrc == CURLM_CALL_MULTI_PERFORM);
    }
}
foreach ($chArr as $k => $ch) {
//    $result[$k] = curl_multi_getcontent($ch); //5 獲取控制程式碼的返回值,不需要
    curl_multi_remove_handle($chHandle, $ch);//6 將$chHandle中的控制程式碼移除
}
curl_multi_close($chHandle); //7 關閉全部控制程式碼
$end_time = microtime(TRUE);
echo sprintf("use time:%.3f s", $end_time - $srart_time);
}

php 實現迴圈請求介面

這種情況針對的是迴圈需要在1S內執行的程式,如果執行頻率超過1S,則直接使用linux 的計劃任務即可

// 無時間限制執行此程式
set_time_limit(0);
// 設定預設時區  北京時間
date_default_timezone_set('PRC');
do {
    //  如果不存在 stop  檔案,則程式停止 並且記錄停止時間
    if (!file_exists(dirname(__FILE__) . '/stop')) {
        $handle = fopen('./ceshi.log', 'a+');
        fwrite($handle, '程式停止時間: ' . date('Y-m-d H:i:s') . "\n");
        fclose($handle);
        exit();
    }
    sleep(4);
    try {
        requestNewOpen();
    } catch (Exception $exception) {
        $handle = fopen('./ceshi.log', 'a+');
        fwrite($handle, 'catch : ' . $exception->getMessage() . "\n");
        fclose($handle);
    }
} while (true);

以上就是php如何實現並行的詳細內容,更多請關注TW511.COM其它相關文章!