博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP的pcntl多进程
阅读量:3646 次
发布时间:2019-05-21

本文共 830 字,大约阅读时间需要 2 分钟。

PHP使用PCNTL系列的函数也能做到多进程处理一个事务。比如我需要从数据库中获取80w条的数据,再做一系列后续的处理,这个时候,用单进程?你可以等到明年今天了。。。所以应该使用pcntl函数了。

假设我想要启动20个进程,将1-80w的数据分成20份来做,主进程等待所有子进程都结束了才退出:

$max = 800000;$workers = 20;$pids = array();for($i = 0; $i < $workers; $i++){    $pids[$i] = pcntl_fork();    switch ($pids[$i]) {        case -1:            echo "fork error : {$i} \r\n";            exit;        case 0:            $param = array(                'lastid' => $max / $workers * $i,                'maxid' => $max / $workers * ($i+1),            );            $this->executeWorker($input, $output, $param);            exit;        default:            break;    }}foreach ($pids as $i => $pid) {    if($pid) {        pcntl_waitpid($pid, $status);    }}

这里当pcntl_fork出来以后,会返回一个pid值,这个pid在子进程中看是0,在父进程中看是子进程的pid(>0),如果pid为-1说明fork出错了。

使用一个$pids数组就可以让主进程等候所有进程完结之后再结束了

来自:

转载地址:http://zemyn.baihongyu.com/

你可能感兴趣的文章
spring-cloud-eureka初体验
查看>>
spring-cloud-ribbon简单使用
查看>>
spring-cloud-feign的简单使用
查看>>
spring-cloud-hystrix简单使用
查看>>
docker批量删除镜像
查看>>
deeping操作系统修改已挂载卷名称
查看>>
设计模式之神奇的单例模式
查看>>
linux系统设置oracle开机自启
查看>>
数据库的五种索引类型
查看>>
设计模式之建造者模式
查看>>
设计模式之代理模式
查看>>
设计模式之门面模式
查看>>
设计模式之装饰器模式
查看>>
设计模式之享元模式
查看>>
设计模式之组合模式
查看>>
设计模式之委派模式
查看>>
设计模式之模板方法模式
查看>>
设计模式之策略模式
查看>>
设计模式之责任链模式
查看>>
怎么成为一个合格的ERP系统管理员
查看>>