
linux 可以用 pcntl_fork 产生一个子进程并返回其pid~
php目前在 windows下很难做到多进程。
不过可以使用多线程,见pthreads,不过使用起来有点小复杂!
//计划任务定时检测master进程是否存在,不存在则启动,以root用户运行
public function checkMaster()
{
$cmd = 'ps axu|grep "UctDataWorker masterRun"|grep -v "grep"|wc -l';
$ret = shell_exec("$cmd");
$ret = rtrim($ret, "\r\n");
if($ret === "0") {
$path = dirname(__FILE__) '/indexphp';
$php_path = Config::$php_path;
$start_master_cmd = "nohup "$php_path" "$path" UctDataWorker masterRun >> /data/log/uctWorkerlog 2>&1 &";
$ret = shell_exec("$start_master_cmd");
}
}
关键点:
php可以直接执行shell命令
ps命令用来罗列进程,根据不同的参数可以获取不同的结果。
ondemand:按请示创建进程数;
dynamic:初始化启动number进程数;
static:固定启动进程数;
php-fpm进程管理一共有三种模式: ondemand、static、dynamic ,我们可以在同一个fpm的master配置三种模式,看下图1。php-fpm的工作模式和nginx类似,都是一个master,多个worker模型。每个worker都在accept本pool内的监听套接字(linux已不存在惊群现象)。
ondemand
在php-fpm启动的时候,不会给这个pool启动任何一个worker,是按需启动,当有连接过来才会启动。
配置文件(我的配置文件地址为:/usr/local/php/etc/php-fpmconf)
当前pool的名字为test
原理
ondemand原理图
1 从上图可以看出,新建worker的触发条件是连接的到来,而不是实际的请求(例如,只进行连接比如telnet,不发请求数据也会新建worker)
2 worker的数量受限于pmmax_children配置,同时受限全局配置processmax(准确的说,三种模式都受限于全局配置)
31秒定时器作用
找到空闲worker,如果空闲时间超过pmprocess_idle_timeout大小,关闭。这个机制可能会关闭所有的worker。
配置项要求
1 pmmax_children> 0
2 pmprocess_idle_timeout> 0,如果不设置,默认10s
优缺点
优点:按流量需求创建,不浪费系统资源(在硬件如此便宜的时代,这个优点略显鸡肋)
缺点:由于php-fpm是短连接的,所以每次请求都会先建立连接,建立连接的过程必然会触发上图的执行步骤,所以,在大流量的系统上master进程会变得繁忙,占用系统cpu资源,不适合大流量环境的部署
dynamic
在php-fpm启动时,会初始启动一些worker,在运行过程中动态调整worker数量,worker的数量受限于pmmax_children配置,同时受限全局配置processmax
当前pool的名字为test
原理
dynamic原理图
1 1秒定时器作用
检查空闲worker数量,按照一定策略动态调整worker数量,增加或减少。增加时,worker最大数量<=max_children· <=全局processmax;减少时,只有idle >pmmax_spare_servers时才会关闭一个空闲worker。
idle > pmmax_spare_servers,关闭启动时间最长的一个worker,结束本次处理
idle >= pmmax_children,打印WARNING日志,结束本次处理
idle < pmmax_children,计算一个num值,然后启动num个worker,结束本次处理
配置项要求
1 pmmin_spare_servers/pmmax_spare_servers有效范围(0,pmmax_children]
2 pmmax_children> 0
3 pmmin_spare_servers<=pmmax_spare_servers
4 pmstart_servers有效范围[pmmin_spare_servers,pmmax_spare_servers]如果没有配置,默认pmmin_spare_servers + (pmmax_spare_servers - pmmin_spare_servers) / 2
优缺点
优点:动态扩容,不浪费系统资源,master进程设置的1秒定时器对系统的影响忽略不计;
缺点:如果所有worker都在工作,新的请求到来只能等待master在1秒定时器内再新建一个worker,这时可能最长等待1s;
static
php-fpm启动采用固定大小数量的worker, 在运行期间也不会扩容,虽然也有1秒的定时器,仅限于统计一些状态信息,例如空闲worker个数,活动worker个数,网络连接队列长度等信息。
当前pool的名字为test
原理
配置项要求
1、pmmax_children> 0 必须配置,且只有这一个参数生效
优缺点
如果配置成static,只需要考虑max_children的数量,数量取决于cpu的个数和应用的响应时间,我司配置的是50。
我司不考虑动态的增加减少那么十几个或者几十个worker,我们的内存没有紧张到这个程度,所以,我们一步到位,把worker数配置到支持最大流量,(哈哈,50也是随便定的,足矣足矣呢)
最后我们再介绍下worker的工作流程
fastcgi与php-fpm的关系一句话解读:fastcgi只是通信应用协议,php-fpm就是实现了fastcig协议,并嵌入了一个 PHP 解释器。
一、php中pcntl_fork函数概述
pcntl_fork()函数是php中用于创建子进程的一个函数,返回创建的子进程的pid。
该函数创建子进程具体fork的过程:
(1)调用该函数即创建一个子进程,创建成功父进程返回子进程的pid,子进程返回0;
(2)创建子进程实际上对父进程的一个拷贝,共享代码空间,拷贝父进程的数据,也就是说父进程改变父进程的数据,子进程改变子进程
二、示例代码分析
1代码示例:
<php
$curr_pid = posix_getpid();//获取当前的进程id
//将当前进程的id写入文件中
echo '当前进程:'$curr_pidPHP_EOL;
//开始创建子进程
$son_pid = pcntl_fork();//返回子进程的id
//查看当前进程
echo '创建子进程之后当前的进程为:'posix_getpid()PHP_EOL;
//创建了子进程之后
if($son_pid > 0){
echo '子进程id:'$son_pidPHP_EOL;
}
2以上代码执行后结果为:
3示例代码分析:
(1)发现创建了子进程之后,系统会切换到子进程中,而子进程中的代码是从含有pcntl_fork函数的那行执行的
(2)创建子进程之后,子进程的代码段是拷贝pcntl_fork函数及之后的代码段,之前的代码段并不拷贝,但是具体的数据变量子进程仍然会拷贝
(3)可见,fork之后程序会分叉执行,即子进程执行
三、pcntl_fork的业务场景举例
1php的多进程中,常用pcntl_fork来实现并发,多用于一些简单工具的实现。
2例如监控工具,想要监控几个不同指标的情形,可以使用主进程监控各指标的配置变化,然后对每个指标分别fork一个子进程来监控其具体的情形,当主进程发现指标的配置改变则kill掉之前的子进程重新创建子进程进行监控。
3主进程进行业务分发 *** 作,子进程进行具体的业务逻辑执行。 (BY三人行慕课)
1
2
3
<php
exec("kill -9 pid,$op,$status);
>
把结果逐行追加到$op的结尾处,只有指定了第二 个参数时,才可以用第三个参数,用来取得命令执行的状态码。$status 1 kill成功,0 是失败(一般情况下是无此进程)。
我的实际项目中是在执行的开始通过getmypid()获取进程id保存到数据库,如果crontab再次触发则把之前的进程kill掉再重新执行一遍以上代码。
守护进程(daemon)是一种特殊的进程,它的生命周期很长,它在后台运行并且没有控制终端(这样可以保证守护进程不会接收到各种来自终端的信号)。
比如:crontab、sshd、nginx等,都会使用守护进程的形式运行,确保可以一直正常的提供服务。
进程管理-防止进程成为僵尸进程
创建好了进程,那么怎么对子进程进行管理呢?
使用信号,对子进程的管理,一般有两种情况:(推荐学习:PHP编程从入门到精通)
posix_kill():此函数并不能顾名思义,它通过向子进程发送一个信号来 *** 作子进程,在需要要时可以选择给子进程发送进程终止信号来终止子进程;
pcntl_waitpid():等待或返回fork的子进程状态,如果指定的子进程在此函数调用时已经退出(俗称僵尸进程),此函数将立刻返回,并释放子进程的所有系统资源,此进程可以避免子进程变成僵尸进程,造成系统资源浪费;
孤儿进程:父进程挂了,子进程被pid=1的init进程接管(wait/waitpid),直到子进程自身生命周期结束被系统回收资源和父进程 采取相关的回收 *** 作
僵尸进程:子进程exit退出,父进程没有通过wait/waitpid获取子进程状态,子进程占用的进程号等描述资源符还存在,产生危害:例如进程号是有限的,无法释放进程号导致未来可能无进程号可用
父进程中使用:pcntl_wait或者pcntl_waitpid的目的就是防止worker成为僵尸进程
作用:使用pcntl_wait()后,在子进程死掉后,父进程也会被停止
最后我们通过下图来简单的总结和描述这个多进程实现的过程:
a34c883897ee2a99833e0ad1e26c1fd4png
进程管理-进程间通信
队列:如Redis,推荐
socket:推荐
管道:实现复杂,且管道(pipe),使用文件形式存在,存在硬盘IO性能瓶颈
信号:承载信息量少,不好管理
进程管理-切换为守护进程
使用&实现
php deadloopphp &
相关资源:Nginx使用的php-fpm的两种进程管理方式及优化-其它代码类资源
打开CSDN APP,看更多技术内容
php 进程管理,PHP 进程管理器 PHP-FPM_阿喵看海外的博客
php-fpm是PHP的一个进程管理器。php下面的众多work进程皆有php-fpm进程管理器管理。 php-fpm的工作原理 php-fpm全名是PHP FastCGI进程管理器。php-fpm启动后会先读phpini,然后再读相应的conf配置文件,conf配置可以覆盖phpini的配置。
继续访问
php-fpm解读-进程管理的三种模式_april2nd的博客_php-fpm
php-fpm进程管理一共有三种模式:ondemand、static、dynamic,我们可以在同一个fpm的master配置三种模式,看下图1。php-fpm的工作模式和nginx类似,都是一个master,多个worker模型。每个worker都在accept本pool内的监听套接字(linux已不存在惊
继续访问
浅谈PHP进程管理
这篇文章是对之前一篇文章的补充和改进, 创建一个主(master)进程,主进程安装定时器,每隔5分钟检测一次队列长度,根据队列长度计算需要的worker进程, 然后创建或者杀掉子进程。这样做的好处是防止队列堆积,任务得不到及时处理。更新业务代码,只需要reload *** 作即可。 整个流程有以下知识点: 创建守护进程的步骤: 设置默认文件权限 fork一个进程,父进程退出 调用setsid创建一个新的会话 将当前工作目录更改为根目录 关闭不再需要的文件描述符 使用信号实现定时器 上一篇定时器依赖于系统的定时任务,这次使用闹钟信号实现,php 530以下的版本依赖于ticks,
php 脚本 fpm缓存,PHP生命周期及fpm(FastCGI进程管理器)的运作方式
PHP在web方式中如何改了文件就立即生效的,重要的几个概念:sapi: 可以简单的理解为php引擎对外的一个统一接口,使得php可以和外部程序进行交互php的生命周期中关键四个调用: MINT -> RINT -> RSHUTDOWN -> MSHUTDOWNfpm: fastcgi进程管理器fpm方式的流程就是:fpm通过sapi接口与php进程交互1fpm启动会调用各扩展
继续访问
Linux下搭建PHP开发环境,Php-Fpm进程管理。_黑夜开发者的博客
目前PHP项目开发几种比较流行的架构搭建中,LNMP在性能方面是最好的,正因为如此,使得LNMP架构逐渐流行起来,今天,前面提到了Nginx部署,由于项目实际环境的需要,今天就在说一下怎么部署PHP。 环境
继续访问
php而为,为高负载而生的 PHP 进程管理器 —— PHP-PM (PPM)
PHP-PM 可以用于php应用程序的进程管理,增压和负载均衡它使用 ReactPHP 实现php的事件驱动和非阻塞I/O。 它是基于 ReactPHP,最好是工作在基于请求-响应式的框架,像Symfony的>
以上就是关于php有办法创建一个进程并且立即返回他的PID吗全部的内容,包括:php有办法创建一个进程并且立即返回他的PID吗、PHP 检测进程是否存在,该怎么处理、PHP进程管理三种模式等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)