在以往的开发项目中,要操作进程就会使用PHP自带的pcntl拓展。但是pcntl存在着许多的不足:
- pcntl没有提供进程间通信的功能
- pcntl不支持重定向标准输入和输出
- pcntl只提供了fork这样原始的接口,容易使用错误
这边我们使用swoole进程管理模块,用来替代PHP
的pcntl
;
场景:日常任务中,有时需要通过php脚本执行一些日志分析,队列处理等任务,当数据量比较大时,可以使用多进程来处理。
准备:安装PHP_swoole拓展;
write($data)
向管道内写入数据。$data
的长度在Linux
系统下最大不超过8K
,MacOS/FreeBSD
下最大不超过2K
start():
执行fork调用,启动子进程。
/** 创建子进程,将数据写入管道,然后启动子进程 */
$process = new \swoole_process([$this, 'sonProcessWork']);
$process->write(json_encode($data_pop));
$pid = $process->start();
swoole_event_add(): 将一个socket加入到底层的reactor
事件监听中;在子进程中处理一些耗时的计算或者操作;
/** 获取管道的业务数据,进行相关的操作 */
public function sonProcessWork(\swoole_process $worker){
$GLOBALS['worker'] = $worker;
swoole_event_add($worker->pipe, function($pipe) {
/******start*你的业务逻辑 *******/
.....
/******end*你的业务逻辑 *******/
$worker->exit(0);
})
}
wait(false)
回收结束运行的子进程
/** 根据信号处理紫禁城 */
private function sig_handler($signo) {
Process::signal(SIGCHLD, function($sig) {
//必须为false,非阻塞模式
while($ret = Process::wait(false)) {
echo "PID={$ret['pid']}\n";
}
});
}
以上就是php_swoole 对进程的基本操作,在实际开发过程中,业务会比较复杂;我们应当配合队列来进行使用。
以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要戳这里 PHP进阶架构师>>>实战视频、大厂面试文档免费获取
来源:oschina
链接:https://my.oschina.net/u/4234147/blog/4490080