php pcntl 进程池_基于pcntl的PHP进程池

2fdcc75eeeb0c8fcc46132fa9f53b255.png

42da39f2e20ab11c9c375cabaf65b3b4.png

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

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

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

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

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

一,安装

用composer安装。

composer require jenner/simple_fork

二,使用

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

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

需要在命令行下运行。

1.进程

使用步骤大致如下:

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

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

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

用起来也很简单

use JennerSimpleForkRunnable;

use JennerSimpleForkProcess;

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 JennerSimpleForkRunnable;

use JennerSimpleForkProcess;

use JennerSimpleForkFixedPool;

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();

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值