关于php-fpm比较重要的几个参数

pm.max_children 设置多大合适?

php-fpm.conf有两个相当重要的参数:php

一个是”max_children”,另外一个是”request_terminate_timeout”。html

 

pm.max_children 表示 php-fpm 能启动的子进程的最大数量。nginx

request_terminate_timeout 表示将执行时间太长的进程直接终止。服务器

个人两个设置的值一个是”40″,一个是”900″,可是这个值不是通用的,而是须要本身计算的。php-fpm

 

1、pm.max_children 多大合适?

这个值原则上是越大越好,php-cgi的进程多了就会处理的很快,排队的请求就会不多。性能

设置”max_children” 也须要根据服务器的性能进行设定。url

 

计算方式以下:spa

通常来讲一台服务器正常状况下每个php-cgi所耗费的内存在20M~30M左右,所以个人”max_children”我设置成40个,20M*40=800M也就是说在峰值的时候全部PHP-CGI所耗内存在800M之内,低于个人有效内存2Gb。日志

而若是我 的”max_children”设置的较小,好比5-10个,那么php-cgi就会“很累“,处理速度也很慢,等待的时间也较长,占用的CPU也很高。server

若是长时间没有获得处理的请求就会出现 504 Gateway Time-out 这个错误,而正在处理的很累的那几个php-cgi若是遇到了问题就会出现 502 Bad gateway 这个错误。

 

max_children较好的设置方式根据req/s(吞吐率,单位时间里服务器处理的最大请求数,单位req/s)来设置,若程序是 100 req/s 的处理能力,那么就设置 100比较好,这是动态来调整的。

 

2、request_terminate_timeout 多大合适?

计算方式以下:

若是你的服务器性能足够好,且宽带资源足够充足,PHP脚本没有循环或BUG的话你能够直接将”request_terminate_timeout”设 置成0s。0s的含义是让PHP-CGI一直执行下去而没有时间限制。

而若是你作不到这一点,也就是说你的PHP-CGI可能出现某个BUG,或者你的宽带不够充足或者其余的缘由致使你的PHP-CGI可以假死那么就建议你给”request_terminate_timeout”赋一个值,这个值能够根 据你服务器的性能进行设定。

通常来讲性能越好你能够设置越高,20分钟-30分钟均可以。因为个人服务器PHP脚本须要长时间运行,有的可能会超过10分钟所以我设置了900秒,这样不会致使PHP-CGI死掉而出现502 Bad gateway这个错误。

 

 

#################################################################################

 

pm = dynamic; 表示使用哪一种进程数量管理方式

 

dynamic表示php-fpm进程数是动态的,最开始是pm.start_servers指定的数量,若是请求较多,则会自动增长,保证空闲的进程数不小于pm.min_spare_servers,若是进程数较多,也会进行相应清理,保证多余的进程数很少于pm.max_spare_servers;

 

static表示php-fpm进程数是静态的,进程数自始至终都是pm.max_children指定的数量,再也不增长或减小。

pm.max_children = 300; 静态方式下开启的php-fpm进程数量

pm.start_servers = 20; 动态方式下的起始php-fpm进程数量

pm.min_spare_servers = 5; 动态方式下的最小php-fpm进程数量

pm.max_spare_servers = 35; 动态方式下的最大php-fpm进程数量

 

数值设置,参考本身的实际硬件配置,能够参考 总内存/30M 来计算。

 

若是dm设置为static,那么其实只有pm.max_children这个参数生效。系统会开启设置数量的php-fpm进程。

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

 

如何判断我选择“pm = dynamic”仍是“pm = static”呢?哪种更好呢?

事实上,跟Apache同样,运行的PHP程序在执行完成后,或多或少会有内存泄露的问题。

这也是为何开始的时候一个php-fpm进程只占用3M左右内存,运行一段时间后就会上升到20-30M的缘由了。

 

对于内存大的服务器(好比8G以上)来讲,用静态的max_children实际上更为稳当,由于这样不须要进行额外的进程数目控制,会提升效率。由于频繁开关php-fpm进程也会有时滞,因此内存够大的状况下开静态效果会更好。数量也能够根据 总内存/30M 获得,好比8GB内存能够设置为100,那么php-fpm耗费的内存就能控制在 2G-3G的样子。

若是内存稍微小点,好比1~2G,那么指定静态的进程数量更加有利于服务器的稳定。这样能够保证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之间。

 

总结:内存小的建议用动态(pm = dynamic),内存大的建议用静态(pm = static)。

 

配置php慢日志,用于监控

request_slowlog_timeout = 10s

slowlog = log/$pool.log.slow

 

配置php-fpm进程可打开的最大文件句柄数,

rlimit_files = 1024

默认1024,此值能够不须要配置

相关文章
相关标签/搜索