php如何实现多进程

php实现多进程的方法:通过pcntl与posix扩展来实现。根据需求我们可以使用pcntl_fork()函数创建子进程,使用pcntl_wait()函数来阻塞当前进程

php多进程S 9 3 [ D U L (需要pcntl,posix扩展支持。

多进程实现只能在cli模式下,在web服务器环境下,会出现无法预期的结果。

(推荐视频教程:php视频教程)

多进程核心函数:

pcntl_fork(创建子| V 5 * e进程)、pcntl_wait(阻塞当前进程)

详细介绍

pcntl_fork:

一次调用两次返回,在父进程中返回子进程pid,在子进程中返回0,出错返回-1。

pcntl_wait ( int &$status [, int $options ] ):

阻塞当前进程,直到任意一个子进程退出或收到一个结束当前进程的信号,注意是结束当前进程的信号,子进程结束发送的SIGCHLD不算。使用$status返回子进程的状态码,并可以指定第二个参数来说明是否以阻塞状态调c o x 7 j $ U c m

阻塞方式调用x k B Q的,函数返回值为子进程的pid,如果没有子进程返回值为-1;

非阻塞方式调用,函数还可以在有子进程在运行但没有结束的子进程时返回0。

pcntl_waitpid ( in) - W 1  j G 1t $pid , int &$status [, int $options ] )

功能同pcntl_wait,区别为waitpid为等待指定pid的子进程。当pid为-1时pcntl_waitpid与pj j n Zcntl_wait 一样。在pcnO & q s o ?tl_wait和pcntl_waitpid两个函数中的$statuN : B Rs中存了子进程的状态信息。

(相关教程推荐:php图文教程)

举例

php中一个始终保持固定个数的子进程在跑。

根据需求使用pcntl_for8 R V ?k(创建子进程)、pcntl_waL J s c ; E } )it(阻塞当前进程)等核z C m ! y B I心函数

代码实现:

<?php
//最大的子进程数量
$maxChildPro = 8;
//当前的子进程数量
$curChildPro = 0;
//当子进程退出时,会触发该函数,当前F ^ P ~ / H ( W子进程数-1
fh K t bunction sig_handleX R b I + =r($sig)
{
global $curChildPro;
switch ($sig) {
case SIGCHLD:
echo 'SIGCHLD', PHP_EOL;
$curChildPro--;
break;
}
}
//配合pcntl_signal使用,简单的说,是为了让系统产生时间云,让信号捕捉函数能够捕捉到信号 | b h量
declare(ticks = 1);
//注册子进程D r Q x ) - $退出时调用的函数。SIGCHLD:在一个进程终止或者停止时,将SIGCH8 K K * I } YLD信号发送给其父进程。
pcntl_signal(SIGCHLD, "sig_handler");
w: + 8  T 7 vhile (true) {
$curChildPro++;
$pid = pcntl_fork();
if ($pidz p l | J # @ #) {
//父进程运行代码,达到上限时父进程阻塞等待任一子进程@ a % x d 7 H O #退出后whi: . M S P m Tle循环继续
if ($curChildProa A a ! G A 8 u >= $maxChildPro) {
pcntl_wait($status);
}
}# } x i 8 } : else {
//子进B f & @ ] L程运行代码
$s = rand(2, 6);
sleep($s);
echo "child sleep $s second quit", PHP_EOL;
exit;
}
}

H # a v @ n ( ; C上就是php如3 [ 0 s n S何实现多进程的详细内容。