PHP的pcntl多進程用法實例
本文實例講述了PHP的pcntl多進程用法。分享給大家供大家參考。具體分析如下:
PHP使用PCNTL系列的函數(shù)也能做到多進程處理一個事務。比如我需要從數(shù)據(jù)庫中獲取80w條的數(shù)據(jù),再做一系列后續(xù)的處理,這個時候,用單進程?你可以等到明年今天了。所以應該使用pcntl函數(shù)了。
假設我想要啟動20個進程,將1-80w的數(shù)據(jù)分成20份來做,主進程等待所有子進程都結(jié)束了才退出:
$max = 800000; $workers = 20; $pids = array(); for($i = 0; $i < $workers; $i++){ $pids[$i] = pcntl_fork(); switch ($pids[$i]) { case -1: echo "fork error : {$i} \r\n"; exit; case 0: $param = array( 'lastid' => $max / $workers * $i, 'maxid' => $max / $workers * ($i+1), ); $this->executeWorker($input, $output, $param); exit; default: break; } } foreach ($pids as $i => $pid) { if($pid) { pcntl_waitpid($pid, $status); } }
這里當pcntl_fork出來以后,會返回一個pid值,這個pid在子進程中看是0,在父進程中看是子進程的pid(>0),如果pid為-1說明fork出錯了。
使用一個$pids數(shù)組就可以讓主進程等候所有進程完結(jié)之后再結(jié)束了
希望本文所述對大家的php程序設計有所幫助。
- php安裝swoole擴展的方法
- PHP框架Swoole定時器Timer特性分析
- PHP+swoole實現(xiàn)簡單多人在線聊天群發(fā)
- PHP使用SWOOLE擴展實現(xiàn)定時同步 MySQL 數(shù)據(jù)
- 詳解PHP swoole process的使用方法
- PHP擴展Swoole實現(xiàn)實時異步任務隊列示例
- PHP+swoole+linux實現(xiàn)系統(tǒng)監(jiān)控和性能優(yōu)化操作示例
- PHP下用Swoole實現(xiàn)Actor并發(fā)模型的方法
- PHP swoole和redis異步任務實現(xiàn)方法分析
- PHP使用pcntl_fork實現(xiàn)多進程下載圖片的方法
- PHP基于swoole多進程操作示例
相關文章
淺析虛擬主機服務器php fsockopen函數(shù)被禁用的解決辦法
以下是對虛擬主機服務器php fsockopen函數(shù)被禁用的解決方法進行了詳細的分析介紹,需要的朋友可以過來參考下2013-08-08WordPress中編寫自定義存儲字段的相關PHP函數(shù)解析
這篇文章主要介紹了WordPress中編寫自定義字段的相關PHP函數(shù)解析,包括對不可見的自定義字段的相關介紹,需要的朋友可以參考下2015-12-12對php 判斷http還是https,以及獲得當前url的方法詳解
今天小編就為大家分享一篇對php 判斷http還是https,以及獲得當前url的方法詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01學習php設計模式 php實現(xiàn)備忘錄模式(Memento)
這篇文章主要介紹了php設計模式中的備忘錄模式,使用php實現(xiàn)備忘錄模式,感興趣的小伙伴們可以參考一下2015-12-12