PHP多进程编程「建议收藏」

PHP多进程编程

大家好,又见面了,我是全栈君。

点击上方“码农编程进阶笔记”,选择“置顶或者星标

优质文章第一时间送达!

           PHP是单进程执行的,PHP处理多并发主要是依赖服务器或PHP-FPM的多进程及它们进程的复用,但PHP实现多进程也意义重大,尤其是在后台Cli模式下处理大量数据或运行后台DEMON守护进程时,多进程的优势不用多说。

 使用多进程的优点:

    1. 使用多进程, 子进程结束以后, 内核会负责回收资源
    2. 使用多进程,子进程异常退出不会导致整个进程Thread退出. 父进程还有机会重建流程.
    3. 一个常驻主进程, 只负责任务分发, 逻辑更清楚.

PHP中实现多进程,Let’s Go.

 

我们需要安装pcnt扩展

pcntl是process control的缩写,通常,php会默认安装这个扩展。使用phpinfo()函数查看扩展是否存在。

PHP多进程编程「建议收藏」

 

使用pcntl_fork() 函数创建子进程

pcntl_fork作用就是创建和当前进程一样的子进程,这个子进程代码段和当前进程一模一样,但是拥有自己的数据段。看一个最简单的创建子进程的方法:

<?php/** * @date 2019-04-03 */// 获取父进程id$parentPid = getmypid(); // 创建子进程$childPid = pcntl_fork();switch($childPid) {
  
      case -1:        print "创建子进程失败!".PHP_EOL;        exit;    case 0:        print "我是子进程,进程ID:{$childPid}".PHP_EOL;        break;    default:        print "我是父进程,进程ID:{$parentPid},子进程ID: {$childPid}".PHP_EOL;}?>
 

pcntl_fork()调用成功以后,一个程序变成了两个程序:一个程序得到的$pid变量值是0,它是子进程;另一个程序得到的$pid的值大于0,这个值是子进程的PID,它是父进程。

输出结果:

PHP多进程编程「建议收藏」

 


 

子进程回收

 

① 阻塞方式
        刚刚有ps么?一般我习惯用ps aux加上grep命令来查找运行着的后台进程。其中有一列STAT,标识了每个进程的运行状态。这里,我们关注状态Z:僵尸(Zombie)。当子进程比父进程先退出,而父进程没对其做任何处理的时候,子进程将会变成僵尸进程。僵尸进程虽然不占什么内存,但是很碍眼。(别忘了它们还占用着PID)

一般来说,在父进程结束之前回收挂掉的子进程就可以了。在pcntl扩展里面有一个pcntl_wait()函数,通过这个方法等待进程结束,然后回收已经结束的进程。

<?php/** * @date 2019-04-03 */$parentPid = getmypid(); // 获取父进程id$childPid = pcntl_fork(); // 创建子进程switch($childPid) {
  
      case -1:        print "创建子进程失败!".PHP_EOL;        exit;    case 0:        print "我是子进程,进程ID:{$childPid}".PHP_EOL;        break;    default:        pcntl_wait($status); // 子进程执行完后才执行父进程        print "我是父进程,进程ID:{$parentPid},子进程ID: {$childPid}".PHP_EOL;}
 

② 非阻塞方式
     阻塞方式失去了多进程的并行性。还有一种方法,既可以回收已经结束的子进程,又可以并行。这就是非阻塞的方式。

<?php/** * @date 2019-04-03 */for ($i = 1; $i <= 5; ++$i) {
  
      $pid = pcntl_fork(); // 创建子进程    if (!$pid) {
  
          sleep(1);        print "In child $i\n";        exit($i);    }}// pcntl_waitpid 第一个参数为 0 代表处理全部子进程while (pcntl_waitpid(0, $status) != -1) {
  
      $status = pcntl_wexitstatus($status);    echo "Child $status completed\n";}

如果父进程先挂了怎么办?

 

会发生什么?什么也不会发生,子进程依旧还在运行。但是这个时候,子进程会被交给1号进程,1号进程成为了这些子进程的继父。1号进程会很好地处理这些进程的资源,当它们结束时1号进程会自动回收资源。所以,另一种处理僵尸进程的临时办法是关闭它们的父进程。

 

最后需要注意的:

进程控制不能被应用在Web服务器环境,当其被用于Web服务环境时可能会带来意外的结果。– 摘自PHP手册

 

参考:

http://www.hackingwithphp.com/16/1/3/getting-into-multiprocessing

http://www.jb51.net/article/71232.htm

http://www.laruence.com/2009/06/11/930.html

http://imhuchao.com/596.html

https://www.pureweber.com/article/php-multi-process-programming-preview/

PHP多进程编程「建议收藏」

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/112019.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 访问数据库使用redis作为mysql的缓存(redis和mysql结合)

    访问数据库使用redis作为mysql的缓存(redis和mysql结合)首先声明一下,我是在一个SSM项目的基础上进行优化的,所以就不进行基础的介绍了。下面我也补充一些知识点:redis:内存型数据库,有持久化功能,具备分布式特性,可靠性高,适用于对读写效率要求都很高,数据处理业务复杂和对安全性要求较高的系统(如新浪微博的计数和微博发布部分系统,对数据安全性、读写要求都很高)。缓存机制说明:所有的查询结果都放进了缓存,也就是把MySQL查询的结果放…

  • vue怎么和后端对接_vue后端框架推荐

    vue怎么和后端对接_vue后端框架推荐简单分享一下jeeplus框架部署liunx服务器跨域问题 ,因为我这个是前后端服务器分离所以配置了俩份java后端配置1.跨域后端配置nginx(图-1)上配置 server { listen 80; server_name xxx.xx.xxx; #后端服务域名 #charset koi8-r; #access_log logs/host.access.log main; locatio

  • springboot(16)Spring Boot使用单元测试[通俗易懂]

    转载自嘟嘟独立博客本文链接地址:SpringBoot干货系列:(十二)SpringBoot使用单元测试前言这次来介绍下SpringBoot中对单元测试的整合使用,本篇会通过以下4点来介绍,基本满足日常需求Service层单元测试Controller层单元测试新断言assertThat使用单元测试的回滚正文SpringBoot中引入单元测试很简单,依赖…

  • 《抓住听众心理——演讲者要知道的100件事》一第 1 章 人们是怎样思考和学习的…

    《抓住听众心理——演讲者要知道的100件事》一第 1 章 人们是怎样思考和学习的…本节书摘来异步社区《抓住听众心理——演讲者要知道的100件事》一书中的第1章,第1.1节,作者:【美】SusanM.Weinschenk译者:杨妩霞,杨煜泳责编:赵轩,更多章节内容可以访问云栖社区“异步社区”公众号查看。第1章 人们是怎样思考和学习的抓住听众心理——演讲者要知道的100件事“我从来没有‘教导’过我的学生;我只是尝…

  • Android EdtiText 添加表情

    Android EdtiText 添加表情

  • 服务器cpu型号后面的字母,Intel 至强 E3服务器CPU后缀解读[通俗易懂]

    服务器cpu型号后面的字母,Intel 至强 E3服务器CPU后缀解读[通俗易懂]三、Intel至强E3服务器CPU后缀解读DIY玩家认识服务器CPU最多的无疑是E3神教,今天我们就总结下XeonE3神教的CPU后缀有什么特色。●V1-V5E3神教!从SNB开始,Intel就推出了E3系列至强CPU。由于阵脚一样,只需升级BIOS就能享用信仰级至强CPU,让2011年开始E3神教开始壮大。Intel也推出了E3的后续型号,与历代酷睿对应,从IvyBridge的V2到Sk…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号