swoole process 多線程實例

<?php
/**
 * 建立多進程
 */
$worker_num         = 30;        // 默認進程數
$workers             = [];        // 進程保存
$redirect_stdout    = false;    // 重定向輸出  ; 這個參數用途等會咱們看效果
for($i = 0; $i < $worker_num; $i++){
    $process = new swoole_process('callback_function', $redirect_stdout);

    // 啓用消息隊列 int $msgkey = 0, int $mode = 2
    $process->useQueue(0, 2);
    $pid = $process->start();

    // 管道寫入內容
    // $process->write(json_encode(['name' => '進程','pid' => $pid]));

    $process->push('我是進程的消息隊列內容');

    // 進程重命名
    //$process->name('child_namne_process_'.$worker->pid);

    // 將每個進程的句柄存起來
    $workers[$pid] = $process;
}


/**
 * 子進程回調
 * @param  swoole_process $worker [description]
 * @return [type]                 [description]
 */
function callback_function(swoole_process $worker)
{
    // $recv = $worker->pop();
    // echo "子輸出主內容: {$recv}".PHP_EOL;
    // $worker->push("我是子進程內容");
    
    $htmlResult = getHtml();

    echo PHP_EOL.$htmlResult.'===='.$worker->pid;

    $worker->exit(0);
    // $worker->exit(0);
}


/**
 * 監控/回收子進程
 */
while(1){
    $ret = swoole_process::wait();
    if ($ret){// $ret 是個數組 code是進程退出狀態碼,
        $pid = $ret['pid'];
        //unset($workers[$pid]);
        echo PHP_EOL."Worker Exit, PID=" . $pid . PHP_EOL;
    }else{
        break;
    }
}


/**
 * 獲取Html內容
 * @return [type] [description]
 */
function getHtml()
{
    $html = file_get_contents('https://segmentfault.com/t/php?type=newest&page=2');
    return true;
}


######### 信號操做,操做信號時主進程不會結束 #################################
/**
 * 監控子進程信號
 */
// swoole_process::signal(SIGTERM, function($signo) {
//     echo "關閉進程";
// });


/**
 * 子進程結束信號(異步信號回調)
 */
// swoole_process::signal(SIGCHLD, function($sig) {
//     //必須爲false,非阻塞模式
//     while($ret =  swoole_process::wait(false)) {
//         echo "PID={$ret['pid']}\n";
//     }
// });
相關文章
相關標籤/搜索