溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php實(shí)現(xiàn)多進(jìn)程的案例

發(fā)布時(shí)間:2020-10-23 14:22:06 來源:億速云 閱讀:296 作者:小新 欄目:編程語言

這篇文章主要介紹了php實(shí)現(xiàn)多進(jìn)程的案例,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

php實(shí)現(xiàn)多進(jìn)程的方法:首先開啟pcntl擴(kuò)展;然后用array_chunk函數(shù)把指定數(shù)組切割為每500個(gè)元素一個(gè)數(shù)組;接著進(jìn)行父進(jìn)程邏輯處理以及子進(jìn)程處理;最后等待子進(jìn)程執(zhí)行結(jié)束即可。

php多進(jìn)程實(shí)現(xiàn)

當(dāng)一個(gè)進(jìn)程執(zhí)行時(shí)間太長,需要是用多進(jìn)程分解任務(wù),縮短程序執(zhí)行時(shí)間

pcntl是php的一個(gè)多進(jìn)程擴(kuò)展,pcntl是process control的縮寫

下面簡單講下pcntl實(shí)現(xiàn)多進(jìn)程的方式。

pcntl_fork — 在當(dāng)前進(jìn)程當(dāng)前位置產(chǎn)生分支(子進(jìn)程)。譯注:fork是創(chuàng)建了一個(gè)子進(jìn)程,父進(jìn)程和子進(jìn)程 都從fork的位置開始向下繼續(xù)執(zhí)行,不同的是父進(jìn)程執(zhí)行過程中,得到的fork返回值為子進(jìn)程 號(hào),而子進(jìn)程得到的是0。

例子:

$habit_class這個(gè)數(shù)組有5000條數(shù)據(jù),所以先用array_chunk函數(shù)把該數(shù)組切割為每500個(gè)元素一個(gè)數(shù)組。
$habit_class = array_chunk($habit_class,500,true);
foreach($habit_class as $k2=>$v2){
$pid = pcntl_fork();
if ($pid == -1) {
die("could not fork");
} elseif ($pid) {
//這里是父進(jìn)程邏輯處理,父進(jìn)程會(huì)返回子進(jìn)程的pid;
} else {// 子進(jìn)程處理,子進(jìn)程返回的pid未0;
foreach($v2 as $k=>$v){
    //進(jìn)行具體業(yè)務(wù)處理
}
}
exit;// 一定要注意退出子進(jìn)程,否則pcntl_fork() 會(huì)被子進(jìn)程再fork,帶來處理上的影響。
}
}
// 等待子進(jìn)程執(zhí)行結(jié)束
while (pcntl_waitpid(0, $status) != -1) {
$status = pcntl_wexitstatus($status);
//echo "Child $status completed\n";
}

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享php實(shí)現(xiàn)多進(jìn)程的案例內(nèi)容對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問題就找億速云,詳細(xì)的解決方法等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI