PHP进程管理器php-fpm的工作原理

发布时间:2020-07-21 17:46:39

来源:亿速云

阅读:133

作者:小新

今天小编给大家分享的是PHP进程管理器php-fpm的工作原理,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。

php-fpm是什么

php-fpm是PHP的一个进程管理器。php下面的众多work进程皆有php-fpm进程管理器管理。

php-fpm的工作原理

php-fpm全名是PHP FastCGI进程管理器。php-fpm启动后会先读php.ini,然后再读相应的conf配置文件,conf配置可以覆盖php.ini的配置。

启动php-fpm之后,会创建一个master进程,监听9000端口(可配置),master进程又会根据fpm.conf/www.conf去创建若干子进程,子进程用于处理实际的业务。

当有客户端(比如nginx)来连接9000端口时,空闲子进程会自己去accept,如果子进程全部处于忙碌状态,新进的待accept的连接会被master放进队列里,等待fpm子进程空闲;这个存放待accept的半连接的队列有多长,由listen.backlog 配置。

如何查看php-fpm进程与子进程

查看php-fpm相关的所有进程。如下图

这里pool www皆是php-fpm的子进程,也就是我们常说的work进程。

查看php-fpm下面的子进程

通过上面的命令,其实我们能够看出php-fpm相关的进程了,如果我们需要更加直观的查看php-fpm的master进程和work进程,可以通过下面的方式进程查看。

这里的5370则是php-fpm的master进程号。通过上面的命令已经很能直观的得出。

通过上面的命令,可以看出php-fpm作为master进程,下面有15个子进程。这里的子进程数都是可以进程自定义配置。通过如下几个参数进程配置:pm = dynamic # 动态创建子进程

pm.max_children = 20 # 最大子进程数

pm.start_servers = 15 # 初始化php-fpm进程时,默认的子进程数

php-fpm参数配置说明

php-fpm全局配置参数#php-fpm的运行权限。

#以什么用户什么组的权限来运行池fpm。

user = www

group = www

#php-fpm的运行方式,可以使端口,也可以使socke文件。

#如果是端口则是走tcp,如果是socket则直接读socket文件,这样性能相对更好。

listen = 127.0.0.1:9000

#拥有socket权限的用户,需要和上面的user、group配置相结合。

#如果采用的端口的方式,则不配置。

listen.owner = www

listen.group = www

listen.mode = 0660

#这是php-fpm端口连接的地址。多个用","隔开。默认任意地址都可以连接。

#例如Nginx和php-fpm不在同一台服务器上,这里的值就是Nginx服务的ip地址。

#当Nginx和php-fpm配置在同一台服务器上,则直接写127.0.0.1即可。

listen.allowed_clients = 127.0.0.1

#pid进程文件存放的位置,当我们启用一个php服务,

#则会自动创建一个该pid文件,其实我们可以直接把该文件理解理解php-fpm的进程号文件,

#两则是等价的。默认为none。

pid = /opt/remi/php72/root/var/run/php-fpm/php-fpm.pid

#错误日志位置,默认:安装路径 #INSTALL_PREFIX#/log/php-fpm.log。

#如果设置为syslog,log就会发送给syslogd服务而不会写进文件里。

error_log = /opt/remi/php72/root/var/log/php-fpm/error.log

#PHP限制的文件扩展名

security.limit_extensions = .php .php3 .php4 .php5 .php7

#系统日志标示,如果跑了多个fpm进程,需要用这个来区分日志是谁的。

syslog.ident = php-fpm

#日记登记,可选:alert, error, warning, notice, debug。

log_level = notice

#紧急重启阈值,需要与下面emergency_restart_interval参数一起配置。

emergency_restart_threshold = 60

# 紧急重启阈值的时间范围。在此参数设置的时间内,

# 出现SIGSEGV或SIGBUS的子进程数超过emergency_restart_threshold参数设置的值。

# 那么fpm就会优雅的重启,值是0表示off这个功能,可用的单位有:s秒,m分,h时,d天。

emergency_restart_interval = 60s

#设置子进程接受主进程复用信号的超时时间。

process_control_timeout = 0

#当动态管理子进程时,fpm最多能fork多少个进程,0表示无限制,

# 这是所有进程池能启动子进程的总和,谨慎使用。

process.max = 128

#设置子进程的优先级,在master进程以root用户启动时有效;

#如果没有设置,子进程会继承master进程的优先级,值范围-19(最高)到20(最低),默认不设置。

process.priority = -19

#设置成no用于调试bug,默认为yes。

daemonize = yes

#master进程最多能打开的文件数量。默认采用系统设置的值。

rlimit_files = 1024

#master进程核心rlimit限制值;可选unlimited或>=0的整数,默认为系统的值。

rlimit_core = 0

#事件处理机制,默认自动检测,可选值:select,poll,

#epoll(linux>=2.5.44),kqueue,/dev/poll,port

events.mechanism = epoll

#fpm想系统发送状态的频率。单位有s,m,h。

#前提是fpm被设置会系统服务。

systemd_interval = 10s

php-fpm的进程进程池配置#php-fpm的队列长度。

listen.backlog = 65535

#php进程池权限,同样要master进程是root用户才有效,

#和上面的全局设置一样,不设置的话会继承master进程的优先级。

process.priority = -19

#子进程管理方式

#static(静态配置,在启动php-fpm时根据该值创建固定的子进程数量);

#dynamic(动态配置,在启动php-fpm时根据pm.start_servers的值初始化对应的子进程数,至少一个子进程);

#ondemand(按需配置,在启动php-fpm时不创建子进程,而是根据请求动态fork子进程);

pm = dynamic

#最大子进程数量

pm.max_children = 5

#初始化子进程数量,与上面的pm = dynamic配置使用。

pm.start_servers = 2

#服务器闲置时最少保持2个子进程,不够这个数就会创建,只适用动态dynamic管理方式

pm.min_spare_servers = 2

#服务器闲置时最多要有几个,多了会kill,只适用动态dynamic管理方式

pm.max_spare_servers = 3

#子进程闲置时间,也就是说子进程没有可处理的任务时,在该之间使就会被killed。

pm.process_idle_timeout = 10s

#每个子进程最大的处理请求数量。在一定程度上可以防止内存泄漏。

pm.max_requests = 500

#php-fpm状态监控的uri

pm.status_path string

#php-fpm监控页面的 ping 网址。

#如果没有设置,则无法访问 ping 页面。

#该页面用于外部检测php-fpm是否存活并且可以响应请求。请注意必须以斜线开头(/)。

ping.path string

#用于定义ping请求的返回响应。返回为 HTTP 200 的 text/plain 格式文本。默认值:pong。

ping.response string

#设置worker的nice(2)优先级(如果设置了的话)。

#该值从 -19(最高优先级) 到 20(更低优先级)。

#默认值:不设置

process.priority int

#检测路径时使用的前缀

prefix string

#访问文件日志,没啥用处,比如yii2每次都记录访问index.php,只是记录真实的PHP文件。

access.log = var/log/$pool.access.log

#php的慢日志

slowlog = var/log/$pool.log.slow

#慢日志时间阈值

request_slowlog_timeout = 2s

#单个请求的超时时间,当php.ini设置的最大执行时间未生效,则交由它来处理。

request_terminate_timeout = 3s

#最大打开句柄数,默认为系统值。

rlimit_files = 1024

#最多的核心使用数,默认为系统分配。

rlimit_core = 0

部分配置演示

php-fpm的backlog大小设置

php-fpm的backlog大小设置与php-fpm的处理能力有关,而不是越大越好。

当该值设置过大,导致php-fpm处理不过来,nginx那边等待超时,断开连接,报504 gateway timeout错。同时php-fpm处理完准备write 数据给nginx时,发现TCP连接断开了,报“Broken pipe”。

当该值设置过小,nginx之类的client请求,根本进入不了php-fpm的accept queue,报“502 Bad Gateway”错。所以,这还得去根据php-fpm的QPS来决定backlog的大小。计算方式最好为QPS=backlog。

php-fpm启动模式

php-fpm以socket启动或者端口启动,这两种的方式根据实际情况进行配置。

nginx和php-fpm在同一台服务器上,这时可以直接用unix socket进程间通信,不走tcp端口通信,可以节约创建连接的时间,从而提高性能。sock文件随便创建到哪里都可以,只要fpm有权限在那个目录里写文件,nginx有权限去读就可以。tcp连接会更稳定,因为有tcp协议保证数据的正确性,但是sock有更少的数据拷贝和上下文切换,更少的资源占用。不过只能在nginx和fpm在同一台机器上才能用socket。

如何选择socket启动还是端口启动。

由于tcp方式相对unix的方式,并发量更高,因此针对并发量高的项目,建议采用tcp方式,现在Nginx配置示例文件默认的也是tcp方式。

使用unix方式,可以优化的点,就是将socket文件放在/dev/shm目录下面,大致的意思,就是该目录下面的文件是不是存储再硬盘中的,而是存储再内存中的。至于硬盘读取和内存读取,谁快谁慢,肯定是内存最快了。

socket方式启动如何查看socke文件。

socket文件是根据上面提到的pid配置项而定的。我们可以直接使用cat命令,查看进程号。

子进程默认启动数量,通过上面的pm = dynamic 配置,我们知道这种方式是动态配置子进程大小的,同时我们也可以设置默认的子进程数。pm = dynamic

pm.max_children = 20

### 默认15个子进程,演示的效果就是上面的shell命令的结果图。

pm.start_servers = 15

当我们尝试设置为3时,显示如下错误信息。

说明,这里的start_servers配置项和min_spare_servers配置是有一定的关系的。我们设置为最小10,结果就能正常启动php-fpm了。

关于PHP进程管理器php-fpm的工作原理就分享到这里了,希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。

php进程原理_PHP进程管理器php-fpm的工作原理相关推荐

  1. 旋流除污器(旋流除砂器)工作原理

    旋流除污器(旋流除砂器)工作原理: 旋流除污器工作原理        旋流除污器(旋流除砂器)是利用离心分离的原理进行除沙,由于进水管安装在筒体的偏心位置,当水通过旋流除砂器进水管后,首先沿筒体的周围 ...

  2. 原理剖析(第 009 篇)ReentrantReadWriteLock工作原理分析

    2019独角兽企业重金招聘Python工程师标准>>> 原理剖析(第 009 篇)ReentrantReadWriteLock工作原理分析 一.大致介绍 1.在前面章节了解了AQS和 ...

  3. FastCGI 进程管理器(FPM)

    FastCGI 进程管理器 FPM(FastCGI 进程管理器)是 PHP FastCGI 的主要实现,包含大部分对高负载网站有用的功能. 它的功能包括: 支持平滑停止/启动的高级进程管理功能: 进程 ...

  4. FastCGI 进程管理器(FPM)配置项目列表

    FPM 使用类似 php.ini 语法的 php-fpm.conf 和进程池配置文件. php-fpm.conf 全局配置段 pid string PID 文件的位置.默认为空. error_log  ...

  5. Spring AOP事务实现原理之事务管理器TransactionManager

    流程图 该图介绍了事务的传播行为 该流通图展示的是TransactionManager具体如何结合事务的传播行为进行事务获取 该流通图展示的是TransactionManager具体如何结合事务的传播 ...

  6. html5前端开发 原理,web前端开发应该明白的浏览器工作原理

    作为前端开发,我们平常跟浏览器打交道的时间也是最多的.在前端面试中,一个较为经典的问题:在浏览器地址中输入url地址,敲回车,发生了什么?浏览器究竟做了什么?相信很多人脑海里都会出现个大概的轮廓,可是 ...

  7. 可编程led灯带原理_SCPSD-250-04-27派克真空压力传感器故障和工作原理

    SCPSD-250-04-27派克PARKER真空压力传感器故障和工作原理 PARKER压力开关现货    PARKER压力传感器特价  派克真空压力传感器  PARKER数字压力开关 2020年还剩 ...

  8. 安检x光机原理计算机实现,安检X光机组成及工作原理(图文)

    安检X光机组成及工作原理40k安检之家 x光机主要由X光管和X光机电源以及控制电路等组成,而X光管又由阴极灯丝(Cathod)和阳极靶(Anode)以及真空玻璃管组成,X光机电源又可分为高压电源和灯丝 ...

  9. 计算机时钟的工作原理,单片机的周期与系统时钟的工作原理

    我们先来理解几个比较重要的概念:时间周期.指令周期.机器周期,以及系统时钟的工作原理. 时钟周期: 时钟周期也叫振荡周期或晶振周期,即晶振的单位时间发出的脉冲数,一般有外部的振晶产生,比如12MHZ= ...

最新文章

  1. 慕课《深入理解计算机系统》袁林枫老师章节测试1-9
  2. 苹果被罚3.1635亿元,因不愿开放第三方支付!
  3. myeclipse中配置weblogic的开发环境
  4. 简述ospf的工作原理_全方位了解OSPF的工作原理以及涉及到的重要技术
  5. numpy(8)-转换维度
  6. 西电计算机考研数学,西安电子科技大学21考研数学高分上岸学长经验分享
  7. 不用 IDE,仅用命令行 + SDK 开发 Android App
  8. matlab怎么定义矩阵变量_MATLAB符号计算(收藏版)
  9. 硬件找工作笔试题、面试题,求职offer指导规划
  10. html img图片不变形等比例缩放,兼容ie6
  11. TCL65V2智能电视机质量怎么样是4K屏幕吗,不要被骗了
  12. SLIC超像素分割方法
  13. Ubuntu:一些普通软件的安装与卸载
  14. ctfshow_2021月饼杯记录
  15. Java专题 基础篇--判断(三元表达式,switch等) +个税计算案例
  16. aws cli 上传文件到s3命令_使用 AWS CLI 分段上传到 Amazon S3
  17. surface pro3深度linux,surface pro4 安装deepin教程
  18. 二进制与其他进制的转换
  19. 酒店微信直播引流获客方案
  20. 计算机专业英语读写比赛,四年级英语读写大赛lpar;初赛rpar;

热门文章

  1. Python中的Re库
  2. 没有经过微软认证的驱动怎么安装?
  3. 斗地主(dfs+模拟)
  4. 扭矩大好还是马力大好_马力和扭矩到底哪个更重要?
  5. 不会盲打的程序员和不懂技术的 CTO
  6. 苹果x和xsmax有什么区别_手机资讯:Apple 认证的翻新产品是什么苹果官方翻新机和全新设备有什么区别...
  7. dnf起源版本无限连接服务器,DNF起源版本BUG不断 爆出无限卡金币跨四已炸
  8. 以太坊学习之Java开发框架web3j的使用---部署合约
  9. 班级网站设计php,班级主页网页设计
  10. 第一章 信息化和信息系统重要知识点