php多进程优化,php多进程编程实现与优化

PHP多进程API

创建子进程@params void@returns int

int pcntl_fork(void)成功时,在父进程执行线程内返回产生的子进程PID,在子进程执行线程内返回0,失败时,在父进程上下文返回-1,不会创建子进程,并且会引发一个php错误

获取当前进程id@params void@returns int

int posix_getpid(void)返回进程id,类型为整型

父进程等待子进程退出@params $status@params $option@return bool

int pcntl_wait(int &$status[,int $options=0])该函数等同于以-1作为参数pid的值并且没有options参数来调用pcntl_waitpid()的函数

进程退出状态@params $status@return bool

bool pcntl_wifexited(int $status)

进程退出码@params $status@return int

int pcntl_wexitstatus(int $status)

简单PHP多进程示例function process_execute($input) {        $pid = pcntl_fork(); //创建子进程

if ($pid == 0) {//子进程

$pid = posix_getpid();

echo "* Process {$pid} was created, and Executed:\n\n";

eval($input); //解析命令

exit;

} else {//主进程

$pid = pcntl_wait($status, WUNTRACED); //取得子进程结束状态

if (pcntl_wifexited($status)) {                        echo "\n\n* Sub process: {$pid} exited with {$status}";

}

}

通过调用php创建子进程接口完成一个子进程的创建,pcntl_fork返回值为0证明进入到子进程内,非0则进入到父进程内部,-1则父进程创建子进程失败。

多个子进程初级版本示例foreach ($clusterList as $key=>$value) {            $pid = pcntl_fork();//创建子进程

if($pid == 0) {//子进程

//do something

} else if($pid == -1) {                //fork error occured

} else {                pcntl_wait($status);

}

}

该实现方式主要逻辑为循环创建一个子进程,并且父进程等待子进程完成退出后,再继续创建下一个子进程

缺点:无法真正体现多进程,实际上时串行的创建子进程

多个子进程优化版本示例foreach ($clusterList as $key=>$value) {            $pid = pcntl_fork();//创建子进程

if($pid == 0) {//子进程

//do something

} else if($pid == -1) {                return false;

}

}        for (;;) {            $ret = pcntl_waitpid(-1,$status,WNOHANG);

if ($ret == -1) {                // error occured

} else if ($ret == 0) {                //all child are existed

break;

} else {                //check sub process exit status

$extFlag = pcntl_wifexited($status);

if(!$extFlag){                    //exited unnormally

}else {                    $extCode = pcntl_wexitstatus($status);

//exited normally

}

}

}

该逻辑通过for循环不断获取子进程的退出状态,直到所有的子进程都退出,真正实现多进程处理。

打开App,阅读手记

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值