本文實(shí)例講述了php swoole多進(jìn)程/多線程用法。分享給大家供大家參考,具體如下:
swoole的多線程其實(shí)就是多進(jìn)程,進(jìn)程創(chuàng)建太多切換的開(kāi)銷很大,如果能用上pthreads建議用pthreads,因?yàn)槲矣玫氖莗hp7nts版本沒(méi)辦法用pthreads
swoole實(shí)例如下:
?php
/**
* 創(chuàng)建多進(jìn)程
*/
$worker_num = 6; // 默認(rèn)進(jìn)程數(shù)
$workers = []; // 進(jìn)程保存
$redirect_stdout = false; // 重定向輸出 ; 這個(gè)參數(shù)用途等會(huì)我們看效果
for($i = 0; $i $worker_num; $i++){
$process = new swoole_process('callback_function', $redirect_stdout);
// 啟用消息隊(duì)列 int $msgkey = 0, int $mode = 2
$process->useQueue(0, 2);
$pid = $process->start();
// 管道寫入內(nèi)容
$process->write('index:'.$i);
$process->push('進(jìn)程的消息隊(duì)列內(nèi)容');
// 將每一個(gè)進(jìn)程的句柄存起來(lái)
$workers[$pid] = $process;
}
/**
* 子進(jìn)程回調(diào)
* @param swoole_process $worker [description]
* @return [type] [description]
*/
function callback_function(swoole_process $worker)
{
$recv = $worker->pop();
echo "子輸出主內(nèi)容: {$recv}".PHP_EOL;
//get guandao content
$recv = $worker->read();
$result = doTask();
echo PHP_EOL.$result.'==='.$worker->pid.'==='.$recv;
$worker->exit(0);
}
/**
* 監(jiān)控/回收子進(jìn)程
*/
while(1){
$ret = swoole_process::wait();
if ($ret){// $ret 是個(gè)數(shù)組 code是進(jìn)程退出狀態(tài)碼,
$pid = $ret['pid'];
echo PHP_EOL."Worker Exit, PID=" . $pid . PHP_EOL;
}else{
break;
}
}
/**
* doTask
* @return [type] [description]
*/
function doTask()
{
sleep(2);
return true;
}
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP進(jìn)程與線程操作技巧總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語(yǔ)法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- php多進(jìn)程中的阻塞與非阻塞操作實(shí)例分析
- php多進(jìn)程并發(fā)編程防止出現(xiàn)僵尸進(jìn)程的方法分析
- php 的多進(jìn)程操作實(shí)踐案例分析
- php 多進(jìn)程編程父進(jìn)程的阻塞與非阻塞實(shí)例分析
- php實(shí)現(xiàn)的簡(jiǎn)單多進(jìn)程服務(wù)器類完整示例
- PHP多進(jìn)程簡(jiǎn)單實(shí)例小結(jié)
- PHP 多進(jìn)程與信號(hào)中斷實(shí)現(xiàn)多任務(wù)常駐內(nèi)存管理實(shí)例方法
- PHP基于swoole多進(jìn)程操作示例
- 詳解PHP多進(jìn)程消費(fèi)隊(duì)列