码迷,mamicode.com
首页 > Web开发 > 详细

PHP-FPM的三种模式和worker进程、master进程详解

时间:2020-06-26 12:57:13      阅读:107      评论:0      收藏:0      [点我收藏+]

标签:配置文件   机制   创建   work   时间   http   php   RKE   默认值   

一:首先介绍PHP-FPM 的三种模式

首先看php配置文件中的说明。

技术图片

 

 

 

(1)pm=static
  始终保持固定数量的worker进程数,由pm.max_children决定,不会动态扩容。

  配置项要求

  1、pm.max_children> 0 必须配置,且只有这一个参数生效

  优缺点

  如果配置成static,只需要考虑max_children的数量,数量取决于cpu的个数和应用的响应时间,

(2)pm=dynamic

  php-fpm启动时,会初始启动一些worker,初始启动worker数决定于pm.max_children的值。在运行过程中动态调整worker数量,worker的数量受限于pm.max_children配置,同时受限全局配置process.max。
  1秒定时器作用,检查空闲worker数量,按照一定策略动态调整worker数量,增加或减少。增加时,worker最大数量<=max_children· <=全局process.max;减少时,只有idle >pm.max_spare_servers时才会关闭一个空闲worker。

  优缺点
  优点:动态扩容,不浪费系统资源
  缺点:如果所有worker都在工作,新的请求到来只能等待master在1秒定时器内再新建一个worker,这时可能最长等待1s


(3)pm=ondemand

  php-fpm启动的时候,不会启动任何一个worker,而是按需启动,只有当连接过来的时候才会启动。
  启动的最大worker数决定于pm.max_children的值,同时受限全局配置process.max。
  1秒定时器作用,如果空闲worker时间超过pm.process_idle_timeout的值(默认值为10s),则关闭该worker。这个机制可能会关闭所有的worker。

  优缺点
  优点:按流量需求创建,不浪费系统资源
  缺点:由于php-fpm是短连接的,所以每次请求都会先建立连接,频繁的创建worker会浪费系统开销。,所以,在大流量的系统上,master进程会变得繁忙,占用系统cpu资源,不适合大流量环境的部署。

 

pm模式设置在/etc/php-fpm.d文件中
可以看到php7.0的默认pm值为dynamic,pm.max_children值为5
技术图片

 

 一个master进程,2个worker进程

技术图片

 

 

worker进程、master进程详解

master只是负责监听管理工作,并不是很多人认为的把客户端发来的请求分给worker进程处理,而是由worker进程负责客户端的请求监听和处理

技术图片

 

 可以看到一旦kill掉worker进程后,会重启一个新的worker进程。因此客户端请求肯定会得到响应处理。master进程负责监听子进程的状态,子进程挂掉之后,会发信号给master进程,然后master进程重新启一个新的worker进程。

PHP-FPM的三种模式和worker进程、master进程详解

标签:配置文件   机制   创建   work   时间   http   php   RKE   默认值   

原文地址:https://www.cnblogs.com/xs-yqz/p/13194318.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!