本文实例讲述了PHP基于swoole多进程操作。分享给大家供大家参考,具体如下:
多个任务同时执行
将顺序执行的任务,转化为并行执行(任务在逻辑上可以并行执行)
比如,我们要对已知的用户数据进行判断,是否需要发送邮件和短信,如果需要发送则发送。
不使用多进程时,我们首先判断是否发送邮件,如果需要则发送;然后再判断是否需要发送短信,如果需要则发送。如果发送邮件耗时2s,发送短信耗时2s,那么我们完成任务大概需要4s左右的时间。
如果我们使用多线程的话,可以开两个线程,一个用于处理邮件,一个用于处理短信,则耗时一共需要2s左右,处理时间缩短了一半。
<?php /** * Created by PhpStorm. * User: zhezhao * Date: 2016/10/20 * Time: 10:37 */ $info = array( "sendmail"=>1, "mailto"=>"12345@qq.com", "sendsms"=>1, "smsto"=>"123456" ); echo "start:".date("Y-m-d H:i:s").PHP_EOL; $mail_process = new swoole_process('sendMail',true); $mail_process->start(); $sms_process = new swoole_process('sendSMS',true); $sms_process->start(); //主进程输出子进程范围内容 echo $mail_process->read(); echo PHP_EOL; echo $sms_process->read(); echo PHP_EOL; echo "end:".date("Y-m-d H:i:s").PHP_EOL; //并行函数 function sendMail(swoole_process $worker){ global $info; if($info['sendmail']==1){ sleep(2); $worker->write("send mail to ".$info['mailto']); } } function sendSMS(swoole_process $worker){ global $info; if($info['sendmail']==1){ sleep(2); $worker->write("send sms to ".$info['smsto']); } }
大任务划分成多个小任务
将循环执行的任务,划分为多个进程执行,提高工作效率
假设我们现在有一个通过curl抓取网页内容的需求,需要抓取10个网页,url地址通过数组读取,每个curl耗时2s。如果我们通过for循环来抓取这10个网页,需要耗时20s,使用多进程我们可以将任务划分成5份,分别由5个进程执行,每个进程抓取2个url,并发执行,共耗时4s,效率提高5倍。
<?php /** * Created by PhpStorm. * User: zhezhao * Date: 2016/10/20 * Time: 10:51 */ $url_arr = array(); for ($i=0;$i<10;$i++){ $url_arr[] = "www.baidu.com?wd=".$i; } echo "start:".date("Y-m-d H:i:s").PHP_EOL; $workers = array(); for ($i=0;$i<5;$i++){ $process = new swoole_process('getContents',true); $process->start(); $process->write($i); $workers[] = $process; } //主进程数据结果 foreach ($workers as $process){ echo $process->read(); echo PHP_EOL; } echo "end:".date("Y-m-d H:i:s").PHP_EOL; function getContents(swoole_process $worker){ $i = $worker->read(); global $url_arr; $res1 = execCurl($url_arr[($i*2)]); $res2 = execCurl($url_arr[($i*2+1)]); echo $res1.PHP_EOL.$res2; } function execCurl($url){ sleep(2); return "handle ".$url." finished"; }
总结
以上两种情况,本质上都是将逻辑上没有先后关系的任务,用多个进程程并发执行,提高效率。
php机制本身不提供多线程的操作,ptcl扩展提供了php操作linux多进程的接口。
个人感觉swoole的多进程process方法更加方便一些。
关于两者的比较:http://wiki.swoole.com/wiki/page/214.html
参考文章:
https://segmentfault.com/a/1190000002946586
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP进程与线程操作技巧总结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
本文向大家介绍Centos7安装swoole扩展操作示例,包括了Centos7安装swoole扩展操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Centos7安装swoole扩展操作。分享给大家供大家参考,具体如下: 我的PHP版本为PHP 7.2.24 更新源 安装需要支持的扩展 安装swoole 安装成功 安装失败 php -m或者 phpinfo()查看不到swoole 解
前言 什么是程序,什么又是进程 进程的创建 让程序在后台运行 查看进程 ID 查看进程的内存映像 查看进程的属性和状态 通过 ps 命令查看进程属性 通过 pstree 查看进程亲缘关系 用 top 动态查看进程信息 确保特定程序只有一个副本在运行 调整进程的优先级 获取进程优先级 调整进程的优先级 结束进程 结束进程 暂停某个进程 查看进程退出状态 进程通信 无名管道(pipe) 有名管道(na
本文向大家介绍基于swoole实现多人聊天室,包括了基于swoole实现多人聊天室的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了swoole创建多人多房间聊天室的具体代码,供大家参考,具体内容如下 核心的swoole代码 基本的cs(client-sercer)结构不变,这里利用的是redis的哈希和set来储存和分组;从而达到了分组,统计,定时推送等功能;最后利用onclose事
本文向大家介绍python多进程操作实例,包括了python多进程操作实例的使用技巧和注意事项,需要的朋友参考一下 由于CPython实现中的GIL的限制,python中的多线程其实并不是真正的多线程,如果想要充分地使用多核CPU的资源,在python中大部分情况我们需要使用多进程。 这也许就是python中多进程类库如此简洁好用的原因所在。在python中可以向多线程一样简单地使用多进程。 一、
imi 中对进程池的创建和运行做了简单封装,基于Swoole\Process\Pool实现。 定义进程池 <?php namespace XinchengApi\api\ProcessPool; use Imi\Process\Annotation\ProcessPool; /** * @ProcessPool(name="进程名称") */ class Sms extends \Imi\
本文向大家介绍PHP基于openssl实现的非对称加密操作示例,包括了PHP基于openssl实现的非对称加密操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP基于openssl实现的非对称加密操作。分享给大家供大家参考,具体如下: 使用非对称加密主要是借助openssl的公钥和私钥,用公钥加密私钥解密,或者私钥加密公钥解密。 1.安装openssl和php的openssl扩展
本文向大家介绍基于PHP函数的操作方法,包括了基于PHP函数的操作方法的使用技巧和注意事项,需要的朋友参考一下 如下所示: 以上这篇基于PHP函数的操作方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
本文向大家介绍Python3基于sax解析xml操作示例,包括了Python3基于sax解析xml操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python3基于sax解析xml操作。分享给大家供大家参考,具体如下: python使用SAX解析xml SAX是一种基于事件驱动的API。 利用SAX解析XML文档牵涉到两个部分:解析器和事件处理器。 解析器负责读取XML文档,并向事