php有办法创建一个进程并且立即返回他的PID吗

php有办法创建一个进程并且立即返回他的PID吗,第1张

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进程管理三种模式等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/9748469.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存