multi-process-pcntl 基于PCNTL的PHP并发处理 封装类

个人声明

作者:于立(wx/yulichenr)
敬告:联系我,请注明来源和来意
本人开发有很多年了,但是很少整理分享,如今趁着清闲就为大家服务了,希望更多地体验到编程带来的快乐。
职场多年下来,技术也算是逐渐地有些积累,但是更重要的是对自身有了更加合理的人生定位。或许,人生的意义,就在于此处的感悟吧。
有对 阅读和写作; 自由工作者; 对大数据信息有领悟者 ,欢迎叨扰。

multi-process-pcntl

基于PCNTL的PHP并发处理 封装类。

对PHP语言底层扩展的的深度解读和生产应用。

github code 地址


使用说明

整理相关的一些资料,封装了下基于 PCNTL 的多进程

生产环境已经校验了,可以放心大胆地使用

引入说明

$ composer require yuli/multi-process-pcntl

使用方法

// 任务数组参数,以此作为切分进程的量化依据,默认被调用方法的第一个参数
$task = range(1, 12);

// 默认 5 个进程,可以进行配置
// 设置的进程数是最大可以取到的进程数
// 会根据任务量 和 进程数进行灵活设定,会根据 count($task)/5 对每个进程内的任务数进行由多到少的分配,后面不足的将不再启动新的进程了
$sync = new MultiProcessPcntl($task);
// $sync = new MultiProcessPcntl($task, 6);

// 支持调用类方法
// 支持传参
$sync->call('test', 'append arg');

运行效果图:

multi-process-pcntl 基于PCNTL的PHP并发处理 封装类

一些相关知识点

PHP本身不支持多进程,但基于Linux的PHP扩展PCNTL却可以提供多进程编程。

PCNTL 函数 - PHP 官网手册中对PCNTL的说明,更细化的需求可以研究深化。


相关推荐