php-fpm参数调优

关于php-fpm.conf参数调优,只对重要的参数进程调优.其它可参数前辈的.php

http://php.net/manual/zh/install.fpm.configuration.php (官方的)html

http://www.cnblogs.com/argb/p/3604340.htmlnginx

http://www.cnblogs.com/jonsea/p/5522018.html数据库

https://www.zybuluo.com/phper/note/89081apache

http://blog.64mazi.com/299/(推荐阅读)bash

关于emergency_restart_threshold 和emergency_restart_interval 参数,设置多少合适
额定内存为4G,拿出一半内存作php使用,即2G,每一个php-fpm进程30m(经验值)
则2g最多能够承受2048/30~=68即设置为
emergency_restart_threshold=60(60个进程数)
emergency_restart_interval=60s(60秒内出现60个进程则优雅的重进php-fpm服务)
pm表示使用那种方式,有两个值能够选择,就是static(静态)或者dynamic(动态)。在更老一些的版本中,dynamic被称做apache-like。这个要注意看配置文件的说明。

下面4个参数的意思分别为:

pm.max_children:静态方式下开启的php-fpm进程数量。
pm.start_servers:动态方式下的起始php-fpm进程数量。
pm.min_spare_servers:动态方式下的最小php-fpm进程数量。
pm.max_spare_servers:动态方式下的最大php-fpm进程数量。

若是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进程数。

公式:

假定一个php-fpm进程为30m计算,若4g内存,拿出一半作的php-fpm使用即2g
$mem=2048
pm = dynamic
pm.max_children = 100 ($mem/20)
pm.start_servers = 75 ($mem/30)min_spare_servers + (max_spare_servers - min_spare_servers) / 2
pm.min_spare_servers = 50 ($mem/40)
pm.max_spare_servers = 50 ($mem/20)服务器

pm.max_children = 50 是最大可建立的子进程的数量。必须设置。这里表示最多只能50个子进程。并发

pm.start_servers = 20 随着php-fpm一块儿启动时建立的子进程数目。默认值:min_spare_servers + (max_spare_servers - min_spare_servers) / 2。这里表示,一块儿启动会有20个子进程。socket

pm.min_spare_servers = 10 
设置服务器空闲时最小php-fpm进程数量。必须设置。若是空闲的时候,会检查若是少于10个,就会启动几个来补上。tcp

pm.max_spare_servers = 30 
设置服务器空闲时最大php-fpm进程数量。必须设置。若是空闲时,会检查进程数,多于30个了,就会关闭几个,达到30个的状态。


实际上的内存消耗是max_children*max_requests*每一个请求使用内存
其它php优化
尽可能少安装PHP模块,最简单是最好(快)的
socket链接FastCGI,/dev/shm是内存文件系统,socket放在内存中确定会快些
cat >> /etc/security/limits.conf <<EOF
* soft nproc 65535
* hard nproc 65535
* soft nofile 65535
* hard nofile 65535
EOF
增长 PHP-FPM 打开文件描述符的限制:
# vi $php_install_dir/etc/php-fpm.conf
rlimit_files = 51200

 如下摘自(麻子来了)http://blog.64mazi.com/299/

1、经常使用参数解释:


1)pm = dynamic #对于专用服务器,pm能够设置为static。
#如何控制子进程,选项有static和dynamic。
若是选择static,则由pm.max_children指定固定的子进程数。
若是选择dynamic,则由pm.max_children、pm.start_servers、pm.min_spare_servers、pm.max_spare_servers 参数决定.
2)pm.max_children 在同一时间最大的进程数 pm.max_children = 120 3)pm.start_servers php-fpm启动时开启的等待请求到来的进程数,默认值为:min_spare_servers + (max_spare_servers - min_spare_servers) / 2 pm.start_servers = 80 4)pm.min_spare_servers 在空闲状态下,运行的最小进程数,若是小于此值,会建立新的进程 pm.min_spare_servers = 60 5)pm.max_spare_servers 在空闲状态下,运行的最大进程数,若是大于此值,会kill部分进程 pm.max_spare_servers = 120 6)pm.process_idle_timeout 空闲多少秒以后进程会被kill,默认为10s pm.process_idle_timeout = 10s 7)pm.max_requests 每一个进程处理多少个请求以后自动终止,能够有效防止内存溢出,若是为0则不会自动终止,默认为0#设置每一个子进程重生以前服务的请求数. 对于可能存在内存泄漏的第三方模块来讲是很是有用的.
若是设置为 '0' 则一直接受请求. 等同于 PHP_FCGI_MAX_REQUESTS 环境变量. 默认值: 0. pm.max_requests = 500 8)pm.status_path 注册的URI,以展现php-fpm状态的统计信息 pm.status_path = /status 其中统计页面信息有: pool 进程池名称 process manager 进程管理器名称(static, dynamic or ondemand) start time php-fpm启动时间 start since php-fpm启动的总秒数 accepted conn 当前进程池接收的请求数 listen queue 等待队列的请求数 max listen queue 自启动以来等待队列中最大的请求数 listen queue len 等待链接socket队列大小 idle processes 当前空闲的进程数 active processes 活动的进程数 total processes 总共的进程数(idle+active) max active processes 自启动以来活动的进程数最大值 max children reached 达到最大进程数的次数 9)ping.path ping url,能够用来测试php-fpm是否存活并能够响应 ping.path = /ping 10)ping.response ping url的响应正文返回为 HTTP 200 的 text/plain 格式文本. 默认值: pong. ping.response = pong 11)pid = run/php-fpm.pid #pid设置,默认在安装目录中的var/run/php-fpm.pid,建议开启 12)error_log = log/php-fpm.log #错误日志,默认在安装目录中的var/log/php-fpm.log 13)log_level = notice #错误级别. 可用级别为: alert(必须当即处理), error(错误状况), warning(警告状况), notice(通常重要信息), debug(调试信息). 默认: notice. 14)emergency_restart_threshold = 60 emergency_restart_interval = 60s #表示在emergency_restart_interval所设值内出现SIGSEGV或者SIGBUS错误的php-cgi进程数若是超过 emergency_restart_threshold个,php-fpm就会优雅重启。这两个选项通常保持默认值。 15)process_control_timeout = 0 #设置子进程接受主进程复用信号的超时时间. 可用单位: s(秒), m(分), h(小时), 或者 d(天) 默认单位: s(秒). 默认值: 0. 16)daemonize = yes #后台执行fpm,默认值为yes,若是为了调试能够改成no。在FPM中,可使用不一样的设置来运行多个进程池。 这些设置能够针对每一个进程池单独设置。 17)listen = 127.0.0.1:9000 #fpm监听端口,即nginx中php处理的地址,通常默认值便可。可用格式为: 'ip:port', 'port', '/path/to/unix/socket'. 每一个进程池都须要设置. 18)listen.backlog = -1 #backlog数,-1表示无限制,由操做系统决定,此行注释掉就行。 19)listen.allowed_clients = 127.0.0.1 #容许访问FastCGI进程的IP,设置any为不限制IP,若是要设置其余主机的nginx也能访问这台FPM进程,listen处要设置成本地可被访问的IP。
默认值是any。每一个地址是用逗号分隔. 若是没有设置或者为空,则容许任何服务器请求链接 20)#unix socket设置选项,若是使用tcp方式访问,这里注释便可。
listen.owner = www
listen.group = www
listen.mode = 0666
#启动进程的账户和组
user = www
group = www
21)request_terminate_timeout = 0 #设置单个请求的超时停止时间. 
该选项可能会对php.ini设置中的'max_execution_time'由于某些特殊缘由没有停止运行的脚本有用. 设置为 '0' 表示 'Off'.当常常出现502错误时能够尝试更改此选项。

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

23)slowlog = log/$pool.log.slow #慢请求的记录日志,配合request_slowlog_timeout使用

24)rlimit_files = 1024 #设置文件打开描述符的rlimit限制. 默认值: 系统定义值默承认打开句柄是1024,可以使用 ulimit -n查看,ulimit -n 2048修改。

25)rlimit_core = 0 #设置核心rlimit最大限制值. 可用值: 'unlimited' 、0或者正整数. 默认值: 系统定义值.

26)chroot = #启动时的Chroot目录. 所定义的目录须要是绝对路径. 若是没有设置, 则chroot不被使用.

27)chdir = #设置启动目录,启动时会自动Chdir到该目录. 所定义的目录须要是绝对路径. 默认值: 当前目录,或者/目录(chroot时)

28)catch_workers_output = yes #重定向运行过程当中的stdout和stderr到主要的错误日志文件中.
若是没有设置, stdout 和 stderr 将会根据FastCGI的规则被重定向到 /dev/null .
默认值: 空.

2、php对子进程的三种管理方式
static: 表示在php-fpm运行时直接fork pm.max_chindren个子进程 dynamic: 表示,运行时forkpm.start_servers个进程,随着负载的状况,动态的调整,最多不超过pm.max_children个进程。同时,保证闲置进程数很多于pm.min_spare_servers数量,不然新的进程会被建立,固然也不是无限制的建立,最多闲置进程不超过pm.max_spare_servers数量,超过则一些闲置进程被清理。 ondemand: 当有请求时,建立进程,启动不建立,最多不超过pm.max_chindren进程数,当进程闲置会在pm.process_idle_timeout秒后被及时释放。

 

3、重要参数的理解与设置

 

【重要一】 request_terminate_timeout = 120 #表示等待120秒后,结束那些没有自动结束的php脚本,以释放占用的资源。 PHP运行在php-fpm模式下,php.ini配置的max_execute_time是无效的,
须要在php-fpm.conf中配置另一个配置项:request_terminate_timeout;如下是官方文档的说明: set_time_limit()和max_execution_time只影响脚本自己执行的时间。
(这两个参数在php.ini中)任何发生在诸如使用system()的系统调用,流操做,数据库操做等的脚本执行的最大时间不包括其中. 还能够是如下状况:
参考:http://zyan.cc/tags/request_terminate_timeout/1/
  1. $ctx = stream_context_create(array(  
  2.    'http' => array(  
  3.        'timeout' => 1 //设置一个超时时间,单位为秒  
  4.        )  
  5.    )  
  6. );  
  7. file_get_contents("http://example.com/", 0, $ctx);  //设置超时时间
 下面4个参数的意思分别为: pm.max_children:静态方式下开启的php-fpm进程数量。 pm.start_servers:动态方式下的起始php-fpm进程数量。 pm.min_spare_servers:动态方式下的最小php-fpm进程数量。 pm.max_spare_servers:动态方式下的最大php-fpm进程数量。 若是dm设置为static,那么其实只有pm.max_children这个参数生效。系统会开启设置数量的php-fpm进程。 若是dm设置为 dynamic,那么pm.max_children参数失效,后面3个参数生效。 系统会在php-fpm运行开始 的时候启动pm.start_serversphp-fpm进程,
而后根据系统的需求动态在pm.min_spare_servers pm.max_spare_servers之间调整php-fpm进程数。 好比说512MVPS,建议pm.max_spare_servers设置为20。至于pm.min_spare_servers,则建议根据服 务器的负载状况来设置,比较合适的值在5~10之间。 pm = dynamic模式很是灵活,也一般是默认的选项。
可是,dynamic模式为了最大化地优化服务器响应,会形成更多内存使用,由于这种模式只会杀掉超出最大闲置进程数(pm.max_spare_servers)的闲置进程, 好比最大闲置进程数是30,而后网站经历了一次访问高峰,高峰期时共动态开启了50个进程所有忙碌,0个闲置进程数,
接着过了高峰期,可能没有一个请求,因而会有50个闲置进程,可是此时php-fpm只会杀掉20子进程,
始终剩下30个进程继续做为闲置进程来等待请求,这可能就是为何过了高峰期后即使请求数大量减小服务器内存使用却也没有大量减小,
也多是为何有些时候重启下服务器状况就会好不少,由于重启后,php-fpm的子进程数会变成最小闲置进程数,而不是以前的最大闲置进程数。 第三种就是文章中提到的pm = ondemand模式,这种模式和pm = dynamic相反,把内存放在第一位,
他的工做模式很简单,每一个闲置进程,在持续闲置了pm.process_idle_timeout秒后就会被杀掉,有了这个模式,
到了服务器低峰期内存天然会降下来,若是服务器长时间没有请求,就只会有一个php-fpm主进程,固然弊端是, 遇到高峰期或者若是pm.process_idle_timeout的值过短的话,没法避免服务器频繁建立进程的问题,所以pm = dynamicpm = ondemand谁更适合视实际状况而定。 【重要二】 pm.max_requests = 500 设置每一个子进程重生以前服务的请求数. 对于可能存在内存泄漏的第三方模块来讲是很是有用的. 若是设置为 0 则一直接受请求.
等同于 PHP_FCGI_MAX_REQUESTS 环境变量. 默认值: 0.这段配置的意思是,当一个 PHP-CGI 进程处理的请求数累积到 500 个后,自动重启该进程。 可是为何要重启进程呢? 通常在项目中,咱们多多少少都会用到一些 PHP 的第三方库,这些第三方库常常存在内存泄漏问题,若是不按期重启 PHP-CGI 进程,势必形成内存使用量不断增加。
所以 PHP-FPM 做为 PHP-CGI 的管理器,提供了这么一项监控功能,对请求达到指定次数的 PHP-CGI 程进行重启,保证内存使用量不增加。 【一些问题及网上解决办法】 正是由于这个机制,在高并发的站点中,常常致使 502 错误,我猜想缘由是 PHP-FPM 对从 NGINX 过来的请求队列没处理好。
不过我目前用的仍是 PHP 5.3.2,不知道在 PHP 5.3.3 中是否还存在这个问题。 目前咱们的解决方法是,把这个值尽可能设置大些,尽量减小 PHP-CGI 从新 SPAWN 的次数,同时也能提升整体性能。
在咱们本身实际的生产环境中发现,内存泄漏并不明显,所以咱们将这个值设置得很是大(204800)。你们要根据本身的实际状况设置这个值,不能盲目 地加大。
相关文章
相关标签/搜索