首页 > 代码库 > php 多进程 父进程的阻塞与非阻塞

php 多进程 父进程的阻塞与非阻塞

php中进程的阻塞,主要是父进程等待子进程退出。

1.php代码如下:

<?php//定义进程数量define(‘FORK_NUMS‘, 5);//用于保存进程pid$pids = array();//我们创建5个子进程for ($i = 0; $i < FORK_NUMS; ++$i) {    $pids[$i] = pcntl_fork();    if ($pids[$i] == -1) {        die(‘fork error‘);    } else if ($pids[$i]) {        //这里是父进程空间,也就是主进程        //我们的for循环第一次进入到这里时,pcntl_wait会挂起当前主进程,等待第一个子进程执行完毕退出        //注意for循环的代码是在主进程的,挂起主进程,相当于当前的for循环也阻塞在这里了        //第一个子进程退出后,然后再创建第二个子进程,到这里后又挂起,等待第二个子进程退出,继续创建第三个,等等。。        pcntl_wait($status);    } else {        //这里是子进程空间        echo "父进程ID: ", posix_getppid(), " 进程ID : ", posix_getpid(), " {$i} \r\n";        //我们让子进程等待3秒,再退出        sleep(3);        exit;    }}

上面代码结果如下:

技术分享

如果我们把pcntl_wait拿到for循环外,会是个什么结果?

2.php代码如下:

<?php//定义进程数量define(‘FORK_NUMS‘, 5);//用于保存进程pid$pids = array();//我们创建5个子进程for ($i = 0; $i < FORK_NUMS; ++$i) {    $pids[$i] = pcntl_fork();    if ($pids[$i] == -1) {        die(‘fork error‘);    } else if ($pids[$i]) {    } else {        //这里是子进程空间        echo "父进程ID: ", posix_getppid(), " 进程ID : ", posix_getpid(), " {$i} \r\n";        //我们让子进程等待3秒,再退出        sleep(3);        exit;    }}//我们把pcntl_waitpid放到for循环外面,那样在for循环里创建子进程就不会阻塞了//但是在这里仍会阻塞,主进程要等待5个子进程都退出后,才退出。foreach ($pids as $pid) {    pcntl_waitpid($pid, $status);}

上面代码结果如下:

技术分享

pcntl_wait的第二个参数可以用来设置主进程不等待子进程退出,继续执行后续代码。

3.php代码如下:

<?php//定义进程数量define(‘FORK_NUMS‘, 5);//用于保存进程pid$pids = array();//我们创建5个子进程for ($i = 0; $i < FORK_NUMS; ++$i) {    $pids[$i] = pcntl_fork();    if ($pids[$i] == -1) {        die(‘fork error‘);    } else if ($pids[$i]) {        //这里是父进程空间,也就是主进程        //这里与1.php的代码只有一点不同,就是加了第二个参数WNOHANG        //for循环到这里时,就不会挂起主进程,而是继续执行后续代码        pcntl_wait($status, WNOHANG);    } else {        //这里是子进程空间        echo "父进程ID: ", posix_getppid(), " 进程ID : ", posix_getpid(), " {$i} \r\n";        //我们让子进程等待3秒,再退出        sleep(3);        exit;    }}//在这里我们等待10秒,不然子进程还没执行完,主进程就退出了,看不出效果sleep(10);

上面代码结果如下:

技术分享

代码3.php与2.php效果一样,pcntl_wait()函数的作用只是用来让父进程等待子进程退出,默认情况下会阻塞主进程。

php 多进程 父进程的阻塞与非阻塞