基于pcntl的PHP进程池

筅森魡賤 提交于 2020-03-11 11:24:06

想必大家都知道可以通过多进程或者多线程的方式实现异步。

PHP多进程编程当前主要有这几种方式,

1>基于pcntl实现多进程,这也是PHP自带的多进程玩法

2>Swoole自己修改PHP内核代码,从而实现多进程,这个看起来比较新

2>Swoole自己修改PHP内核代码,从而实现多进程 inple_fork这个库,实现了多进程和进程池。

一,安装

用composer安装。

composer require jenner/simple_fork

二,使用

simple_fork这个库自带了很多内容,在此主要跟大家分享进程和进程池的使用,其他内容可以自行查看demo。

没有用过composer的朋友,需要根据自己的代码路径,导入autoload.php,在此略过。

需要在命令行下运行。

1,进程

使用步骤大致如下:

#1,任务是一个实现了Runnable接口的类,或者直接用callback也可以。

#2,初始化子进程Process,并把任务实例作为参数传递过去

#3,最后start开启子进程,wait用于等待子进程运行结束(否则会出现僵尸进程)。

用起来也很简单

use Jenner\SimpleFork\Runnable;

use Jenner\SimpleFork\Process;

class Task implements Runnable
{

    /**
     * @return void
     */
    public function run()
    {
        echo "I am a sub process" . PHP_EOL;
    }
}

$process = new Process(new Task());
$process->start();
$process->wait();

2,进程池

更多的时候,我们会用进程池去异步执行一些列任务。

进程池在初始化的时候,需要声名进程池的最大容量,超过该容量后新添加的进程都会放在队列,直到有新的空余空间释放出来,才会执行新增的任务。

同样需要用wait等待进程池内的所有子进程执行完毕,避免出现僵尸进程。

use Jenner\SimpleFork\Runnable;

use Jenner\SimpleFork\Process;
use Jenner\SimpleFork\FixedPool;


class Task implements Runnable
{

    /**
     * @return mixed
     */
    public function run()
    {
        sleep(10);
        echo getmypid() . ':done' . PHP_EOL;
    }
}

$pool = new  FixedPool(2);
$pool->execute(new  Process(new Task()));
$pool->execute(new  Process(new Task()));
$pool->execute(new  Process(new Task()));

$pool->wait();

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家需要请戳这里

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!