php 多进程中的信号问题

时间:2021-10-15 19:40:19

1.以下代码sleep时间远小于20

<?php
// 当子进程退出时,会触发该函数
function sig_handler($sig) {
switch($sig) {
case SIGCHLD:
echo 'SIGCHLD received'."n";
}
} pcntl_signal(SIGCHLD, "sig_handler");// 注册子进程退出时调用的函数 $start = time(); $sub_process_cnt = 20;
for($i=0;$i<$sub_process_cnt;$i++) { sleep(1); $pid = pcntl_fork();
if ($pid == 0) { exit(-1);
}
} $status = 0; for ($k=0; $k<$sub_process_cnt; $k++)
{
pcntl_waitpid(-1, $status );
} $end = time();
$usage = $end - $start;
print "End, use: ".$usage." seconds" ; ?>

2.原因:sleep过程中被子进程返回的信号中断。

3.解决办法:

pcntl_signal(SIGCHLD, SIG_IGN ); //忽略子进程返回信号

全部代码如下

<?php
// 当子进程退出时,会触发该函数
function sig_handler($sig) {
switch($sig) {
case SIGCHLD:
echo 'SIGCHLD received'."n";
}
} pcntl_signal(SIGCHLD, SIG_IGN );// 注册子进程退出时调用的函数 $start = time(); $sub_process_cnt = 20;
for($i=0;$i<$sub_process_cnt;$i++) { sleep(1); $pid = pcntl_fork();
if ($pid == 0) { exit(-1);
}
} $status = 0; for ($k=0; $k<$sub_process_cnt; $k++)
{
pcntl_waitpid(-1, $status );
} $end = time();
$usage = $end - $start;
print "End, use: ".$usage." seconds" ; ?>