PHP Linux Cli 模式下利用 pcntl_fork实现多进程处理

来源:互联网 发布:福建护理网络教育 编辑:程序博客网 时间:2024/05/16 17:38
<?php/** * PHP Linux Cli 模式下利用 pcntl_fork实现多进程处理 *  */// 进程数$processes = 5;// 所有任务就是是为了输出0到9999中的所有数字// 这些数字将被分成5个块,代表5个进程,// 当输出的时候我们就可以看到所有进程的执行顺序$tasks = range ( 0, 9999 );$blocks = array ();// 将任务按进程分块foreach ( $tasks as $i ) {$blocks [($i % $processes)] [] = $i;}foreach ( $blocks as $blockNum => $block ) {// 通过pcntl得到一个子进程的PID$pid = pcntl_fork ();if ($pid == - 1) {// 错误处理:创建子进程失败时返回-1.die ( 'could not fork' );} else if ($pid) {// 父进程逻辑// 等待子进程中断,防止子进程成为僵尸进程。// WNOHANG为非阻塞进程,具体请查阅pcntl_wait PHP官方文档pcntl_wait ( $status, WNOHANG );} else {// 子进程逻辑foreach ( $block as $i ) {echo "I'm block {$blockNum},I'm  printing:{$i}\n";sleep ( 1 );}// 为避免僵尸进程,当子进程结束后,手动杀死进程if (function_exists ( "posix_kill" )) {posix_kill ( getmypid (), SIGTERM );} else {system ( 'kill -9' . getmypid () );}exit ();}}

0 0
原创粉丝点击