php多进程应用场景主要是非web端,fpm下是不支持多进程的,非类linux操作系统都不支持,请在cli模式使用.可以使用多进程做任务分发,批量计算,批量文件处理,批量爬虫,网络运维等等。下面看一份简单的入门demo
//创建子进程
$pid=pcntl_fork();
//返回-1,创建失败,不会创建子进程,并引发PHP错误
if($pid==-1)
{
exit('创建子进程失败!');
}
else if($pid)
{
//父进程得到子进程号,这里是父进程执行的逻辑
//为什么父进程得到?因为是父进程创建的子进程
}
else
{
//子进程得到进程号为0,这里是子进程的逻辑
//为什么子进程得到0,因为是父进程创建的它
}解析:
pcntl_fork会创建一个子进程,当创建了子进程后,后面的执行的代码是并行的.父进程和子进程 都从fork的位置开始向下继续执行,不同的是父进程执行过程中,得到的fork返回值为子进程号,而子进程得到的是0。为什么?我在注释中已经注释了。
下面创建10个进程来执行网络请求任务
//创建10个进程去访问某个文章url
for ($i=0; $i <10 ; $i++) {
//创建子进程
$pid=pcntl_fork();
//返回-1,创建失败,不会创建子进程,并引发PHP错误
if($pid==-1)
{
echo ('创建子进程失败!');
}
else if($pid)
{
//我是父亲进程逻辑模块
//pcntl_wait($status);//如果开启阻塞,那么父进程只能等子进程执行完成,再执行,可设置子进程的sleep进行测试
$id = getmypid();
echo '我是主进程id:'.$id.',我是子进程id:'.$pid."\r\n";
}
else
{
//我是子进程逻辑模块
$url='https://blog.20230611.cn/?id=158';
sleep(1);
file_get_contents($url);
//我执行完成我就退出,如果不退出将会造成继续fork
exit();
}
}解析:
以上代码创建10个进程对我的url分别请求一次,然后退出进程。其中父进程中pcntl_wait()是为了等待子进程中断,防止子进程成为僵尸进程,如果你开启了它,那么父进程将会等待并行的子进程完成并退出才执行。需要注意的是子进程使用完成及时exit,否则继续fork系统开销很大。为了保证系统稳定最好使用pcntl_signal()处理进程管理
通过该函数可以获取指定端口的页面源码,还能设置超时时间、自定义数据包,fsockopen 也很强大,但是比较偏底层。可以自定义设置header头信息,强大至极。$socket=fsockopen('www.jd88.net','80',$errno,$errstr,3...
在一个正式项目中操作人员提交239个产品信息进行保存,但是系统却提示没有提交239个产品,于是开启错误信息,显示如下:Warning: Unknown: Input variables exceeded 1000. To incr...
<?php /** * @throws Exception */ function curl() { throw new \Exception('err...
<?php //php7+ define('CONFIG', [ 'MYSQL' => '127.0.0.1',  ...
本教程使用的定时任务基于EasyTak,EasyTask官方文档:https://gitee.com/392223903/EasyTask(1).安装tp5.0或者5.1composer create-project topthink/think=5.0.* tp5&n...
本文基于Laravel Framework 6.17.1版本(1).创建项目(依赖真多,如此臃肿)composer create-project --prefer-dist laravel/laravel blog(2).安装定时任务composer包&nbs...