<?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"; // } // });