linux下的php-fpm参数配置介绍与参数优化说明

PHP-fpm.conf重要参数详解

PHP-fpm.pid #pid设置,认在安装目录中的var/run/PHP-fpm.pid,建议开启

PHP-fpm.log #错误日志,认在安装目录中的var/log/PHP-fpm.log

错误级别. 可用级别为: alert(必须立即处理),error(错误情况),warning(警告情况),notice(一般重要信息),debug(调试信息). 认: notice.

错误的php-cgi进程数如果超过 emergency_restart_threshold个,PHP-fpm就会优雅重启。这两个选项一般保持认值。

默认单位: s(秒). 认值: 0.

后台执行fpm,认值为yes,如果为了调试可以改为no。在FPM中,可以使用不同的设置来运行多个进程池。 这些设置可以针对每个进程池单独设置。

Nginx中PHP处理的地址,一般认值即可。可用格式为: 'ip:port','port','/path/to/unix/socket'. 每个进程池都需要设置.

Nginx也能访问这台FPM进程,listen处要设置成本地可被访问的IP。认值是any。每个地址是用逗号分隔. 如果没有设置或者为空,则允许任何服务器请求连接

启动进程的帐户和组

PHP_FCGI_MAX_REQUESTS 环境变量. 认值: 0.

页面的网址. 如果没有设置,则无法访问状态页面. 认值: none. munin监控会使用到

页面的ping网址. 如果没有设置,则无法访问ping页面. 该页面用于外部检测FPM是否存活并且可以响应请求. 请注意必须以斜线开头 (/)。

默认值: pong.

PHP.ini设置中的'max_execution_time'因为某些特殊原因没有中止运行的脚本有用. 设置为 '0' 表示 'Off'.当经常出现502错误时可以尝试更改此选项。

一个请求该设置的超时时间后,就会将对应的PHP调用堆栈信息完整写入到慢日志中. 设置为 '0' 表示 'Off'

文件打开描述符的rlimit限制. 认值: 系统定义值认可打开句柄是1024,可使用 ulimit -n查看,ulimit -n 2048修改

默认值: 系统定义值.

绝对路径. 如果没有设置,则chroot不被使用.

自动Chdir到该目录. 所定义的目录需要是绝对路径. 认值: 当前目录,或者/目录(chroot时)

重定向运行过程中的stdout和stderr到主要的错误日志文件中. 如果没有设置,stdout 和 stderr 将会根据FastCGI的规则被重定向到 /dev/null . 认值: 空.

PHP-fpm参数调优

表示使用哪种进程数量管理方式

PHP-fpm进程数是动态的,最开始是pm.start_servers指定的数量,如果请求较多,则会自动增加,保证空闲的进程数不小于pm.min_spare_servers,如果进程数较多,也会进行相应清理,保证多余的进程数不多于pm.max_spare_servers

PHP-fpm进程数是静态的,进程数自始至终都是pm.max_children指定的数量,不再增加或减少

PHP-fpm进程数量 PHP-fpm进程数量 PHP-fpm进程数量 PHP-fpm进程数量

如果pm为static,那么其实只有pm.max_children这个参数生效。系统会开启设置数量PHP-fpm进程

如果pm为dynamic,那么pm.max_children参数失效,后面3个参数生效。系统会在PHP-fpm运行开始的时候启动pm.start_servers个PHP-fpm进程,然后根据系统的需求动态在pm.min_spare_servers和pm.max_spare_servers之间调整PHP-fpm进程数

那么,对于我们的服务器,选择哪种pm方式比较好呢?事实上,跟Apache一样,运行的PHP程序在执行完成后,或多或少会有内存泄露的问题。这也是为什么开始的时候一个PHP-fpm进程只占用3M左右内存,运行一段时间后就会上升到20-30M的原因了。

对于内存大的服务器(比如8G以上)来说,指定静态的max_children实际上更为妥当,因为这样不需要进行额外的进程数目控制,会提高效率。因为频繁开关PHP-fpm进程也会有时滞,所以内存够大的情况下开静态效果会更好。数量也可以根据 内存/30M 得到,比如8GB内存可以设置为100,那么PHP-fpm耗费的内存就能控制在 2G-3G的样子。如果内存稍微小点,比如1G,那么指定静态的进程数量更加有利于服务器的稳定。这样可以保证PHP-fpm只获取够用的内存,将不多的内存分配给其他应用去使用,会使系统的运行更加畅通。

对于小内存的服务器来说,比如256M内存的VPS,即使按照一个20M的内存量来算,10个php-cgi进程就将耗掉200M内存,那系统的崩溃就应该很正常了。因此应该尽量地控制PHP-fpm进程的数量,大体明确其他应用占用的内存后,给它指定一个静态的小数量,会让系统更加平稳一些。或者使用动态方式,因为动态方式会结束掉多余的进程,可以回收释放一些内存,所以推荐在内存较少的服务器或VPS上使用。具体最大数量根据 内存/20M 得到。比如说512M的VPS,建议pm.max_spare_servers设置为20。至于pm.min_spare_servers,则建议根据服务器的负载情况来设置,比较合适的值在5~10之间。

在4G内存的服务器上200就可以(我的1G测试机,开64个是最好的,建议使用压力测试获取最佳值)

Nginx PHP-fpm配置过程中最大问题是内泄漏出问题:服务器的负载不大,但是内存占用迅速增加,很快吃掉内存接着开始吃交换分区,系统很快挂掉!其实根据官方的介绍,php-cgi不存在内存泄漏,每个请求完成后php-cgi会回收内存,但是不会释放给操作系统,这样就会导致大量内存被php-cgi占用。

官方的解决办法是降低PHP_FCGI_MAX_REQUESTS的值,如果用的是PHP-fpm,对应的PHP-fpm.conf中的就是max_requests,该值的意思是发送多少个请求后会重启该线程,我们需要适当降低这个值,用以让PHP-fpm自动的释放内存,不是大部分网上说的51200等等,实际上还有另一个跟它有关联的值max_children,这个是每次PHP-fpm会建立多少个进程,这样实际上的内存消耗是max_children*max_requests*每个请求使用内存,根据这个我们可以预估一下内存的使用情况,就不用再写脚本去kill了。

最大执行时间,在PHP.ini中也可以进行配置(max_execution_time)

增加PHP-fpm打开文件描述符的限制

PHP-fpm.conf的参数明说大家只要多看几遍应该就可能记住了,至于 PHP-fpm性能方案应该根据实际情况而定,多测试几次得出最佳配置方案

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...