php-fpm介绍及配置

php-fpm是什么

全称是php fastcgi process manager即php fastcgi进程管理器,相比fastcgi静态的唤起cgi,fpm能根据访问的压力动态的唤起cgi进程和销毁以到达动态的调整cgi数量,这样可以有效的使用内存。除此之外还有其它的一些优点,比如,fpm还可以平滑的重载php配置;由于fpm是使用Unix-Socket来和服务器通讯,所以也不用再配置cgi端口;fpm有更好的状态输出和slowlog日志,502的时候能给出更多的错误细节。

php-fpm配置

从php5.3.3版本开始就已经集成了fpm,不再是第三方的包了,如果使用的是php5.3.3以前的版本就得自己去安装fpm包了,对于php5.2.x的版本,fpm的配置文件还是xml格式,php5.3.x开始fpm配置文件就已经支持ini格式了。

下面是一个ini格式的配置文件

  1. ;this configuration is for PHP 5.3.10 for heavy loaded servers
  2. [global]
  3. error_log = syslog
  4. log_level = error
  5. rlimit_files = 655360
  6. rlimit_core = 0
  7. [myapp]
  8. user = nobody
  9. group = nobody
  10. listen = fpm.sock
  11. listen.allowed_clients = 127.0.0.1
  12. pm = dynamic
  13. pm.max_children = 1000
  14. pm.start_servers = 20
  15. pm.min_spare_servers = 10
  16. pm.max_spare_servers = 30
  17. pm.max_requests = 500
  18. ; system max load (request number) = max_children * max_requests = 500,000
  19. pm.status_path = /fpm_status
  20. ping.path = /status
  21. ping.response = ok
  22. slowlog = /data/phplogs/phpfpm_slow.log
  23. request_slowlog_timeout = 3s
  24. ;listen.backlog = 262144
  25. ; The timeout for serving a single request after which the worker process will
  26. ; be killed. This option should be used when the ‘max_execution_time‘ ini option
  27. ; does not stop script execution for some reason. A value of ‘0‘ means ‘off‘.
  28. ; Available units: s(econds)(default), m(inutes), h(ours), or d(ays)
  29. ; Default Value: 0
  30. ;request_terminate_timeout = 0
  31. rlimit_files = 655360
  32. rlimit_core = 0
  33. security.limit_extensions = .php .html
  34. php_admin_value[‘date.timezone‘] = ‘Asia/Shanghai‘
;this configuration is for PHP 5.3.10 for heavy loaded servers

[global]
error_log = syslog
log_level = error
rlimit_files = 655360
rlimit_core = 0

[myapp]
user = nobody
group = nobody
listen = fpm.sock
listen.allowed_clients = 127.0.0.1

pm = dynamic
pm.max_children = 1000
pm.start_servers = 20
pm.min_spare_servers = 10
pm.max_spare_servers = 30
pm.max_requests = 500
; system max load (request number) = max_children * max_requests = 500,000

pm.status_path = /fpm_status
ping.path = /status
ping.response = ok

slowlog = /data/phplogs/phpfpm_slow.log
request_slowlog_timeout = 3s
;listen.backlog = 262144

; The timeout for serving a single request after which the worker process will
; be killed. This option should be used when the ‘max_execution_time‘ ini option
; does not stop script execution for some reason. A value of ‘0‘ means ‘off‘.
; Available units: s(econds)(default), m(inutes), h(ours), or d(ays)
; Default Value: 0
;request_terminate_timeout = 0

rlimit_files = 655360
rlimit_core = 0

security.limit_extensions = .php .html

php_admin_value[‘date.timezone‘] = ‘Asia/Shanghai‘

参数说明:

 

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

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

emergency_restart_threshold int
如果子进程在emergency_restart_interval设定的时间内收到该参数设定次数的SIGSEGV 或者 SIGBUS退出信息号,则FPM会重新启动。 0 表示 ‘关闭该功能’. 默认值: 0 (关闭).

emergency_restart_interval mixed
emergency_restart_interval用于设定平滑重启的间隔时间. 这么做有助于解决加速器中共享内存的使用问题. 可用单位: s(秒), m(分), h(小时), 或者 d(天). 默认单位: s(秒). 默认值: 0 (关闭).

process_control_timeout mixed
设置子进程接受主进程复用信号的超时时间. 可用单位: s(秒), m(分), h(小时), 或者 d(天) 默认单位: s(秒). 默认值: 0.

daemonize boolean
设置FPM在后台运行. 设置 ‘no’ 将 FPM 保持在前台运行用于调试. 默认值: yes.

运行配置区段
在FPM中,可以使用不同的设置来运行多个进程池。 这些设置可以针对每个进程池单独设置。

listen string
设置接受FastCGI请求的地址. 可用格式为: ‘ip:port’, ‘port’, ‘/path/to/unix/socket’. 每个进程池都需要设置.

listen.backlog int
设置 listen(2) 的半连接队列长度. ‘-1′ 表示无限制. 默认值: -1.

listen.allowed_clients string
设置允许连接到FastCGI的服务器IPV4地址. 等同于PHP FastCGI (5.2.2+)中的 FCGI_WEB_SERVER_ADDRS环境变量. 仅对TCP监听起作用. 每个地址是用逗号分隔. 如果没有设置或者为空,则允许任何服务器请求连接. 默认值: any.

listen.owner string
如果使用,表示设置Unix套接字的权限. 在Linux中,读写权限必须设置,以便用于WEB服务器连接. 在很多BSD派生的系统中可以忽略权限允许自由连接. 默认值: 运行所使用的用户合租, 权限为0666.

listen.group string
参见 listen.owner.

listen.mode string
参见 listen.owner.

user string
FPM 进程运行的Unix用户. 必须设置.

group string
FPM 进程运行的Unix用户组. 如果没有设置,则默认用户的组被使用.

pm string
设置进程管理器如何管理子进程. 可用值: static, dynamic. 必须设置.

static – 子进程的数量是固定的 (pm.max_children).

dynamic – 子进程的数量在下面配置的基础上动态设置: pm.max_children, pm.start_servers, pm.min_spare_servers, pm.max_spare_servers.

pm.max_children int
子进程的数量,pm 设置为 static 时表示创建的, pm 设置为 dynamic 时表示最大可创建的. 必须设置.

该选项设置可以同时提供服务的请求数限制. 类似 Apache 的 mpm_prefork 中 MaxClients 的设置和 普通PHP FastCGI中的 PHP_FCGI_CHILDREN 环境变量.

pm.start_servers in
设置启动时创建的子进程数目. 仅在 pm 设置为 dynamic 时使用. 默认值: min_spare_servers + (max_spare_servers – min_spare_servers) / 2.

pm.min_spare_servers int
设置空闲服务进程的最低数目. 仅在 pm 设置为 dynamic 时使用. 必须设置.

pm.max_spare_servers int
设置空闲服务进程的最大数目. 仅在 pm 设置为 dynamic 时使用. 必须设置.

pm.max_requests int
设置每个子进程重生之前服务的请求数. 对于可能存在内存泄漏的第三方模块来说是非常有用的. 如果设置为 ’0′ 则一直接受请求. 等同于 PHP_FCGI_MAX_REQUESTS 环境变量. 默认值: 0.

pm.status_path string
FPM状态页面的网址. 如果没有设置, 则无法访问状态页面. 默认值: none.

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

ping.response string
用于定义ping请求的返回相应. 返回为 HTTP 200 的 text/plain 格式文本. 默认值: pong.

request_terminate_timeout mixed
设置单个请求的超时中止时间. 该选项可能会对php.ini设置中的’max_execution_time’因为某些特殊原因没有中止运行的脚本有用. 设置为 ’0′ 表示 ‘Off’. Available units: s(econds)(default), m(inutes), h(ours), or d(ays). Default value: 0.

request_slowlog_timeout mixed
当一个请求该设置的超时时间后,就会将对应的PHP调用堆栈信息完整写入到慢日志中. 设置为 ’0′ 表示 ‘Off’. 可用单位: s(秒)(默认), m(分), h(小时), 或者 d(天). 默认值: 0.

slowlog string
慢请求的记录日志. 默认值: #INSTALL_PREFIX#/log/php-fpm.log.slow.

rlimit_files int
设置文件打开描述符的rlimit限制. 默认值: 系统定义值.

rlimit_core int
设置核心rlimit最大限制值. 可用值: ‘unlimited’ 、0或者正整数. 默认值: 系统定义值.

chroot string
启动时的Chroot目录. 所定义的目录需要是绝对路径. 如果没有设置, 则chroot不被使用.

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

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

nginx配置

如果使用unix-socket来与nginx配合,nginx中的配置也要做相应的更改

1. 在ngnix配置的server_name下面声明全局的fpm变量

 

  1. server {
  2. listen 80 ;
  3. server_name xxx;
  4. #在这里插入,设置为全局变量
  5. set $fpm_sock ‘unix:/var/run/myapp/fpm.sock‘;
  6. ...
  7. }
server {     
       listen 80 ;     
       server_name xxx;    
       #在这里插入,设置为全局变量     
       set    $fpm_sock ‘unix:/var/run/myapp/fpm.sock‘;
        ...
}

2. 然后改造所有 fastcgi_pass 字段

 

 

  1. location = / {
  2. include fastcgi_params;
  3. root xxx/apps/fnt;
  4. fastcgi_pass $fpm_sock;
  5. fastcgi_index index.php;
  6. fastcgi_param SCRIPT_FILENAME xxx/apps/fnt/index.php ;
  7. }
location = / {     
     include        fastcgi_params;     
     root           xxx/apps/fnt;     
     fastcgi_pass   $fpm_sock;     
     fastcgi_index  index.php;     
     fastcgi_param  SCRIPT_FILENAME  xxx/apps/fnt/index.php ;      
}

 

fpm status

在nginx.conf里配置

  1. server {
  2. listen 8360;
  3. server_name localhost;
  4. location /fpm_status {
  5. if ( $arg_sid = ‘‘ ) {
  6. rewrite ^ /fpm_list last;
  7. }
  8. include fastcgi_params;
  9. fastcgi_pass unix:/var/run/$arg_sid/fpm.sock;
  10. }
  11. #列出所有正在运行的fpm-sock
  12. location /fpm_list {
  13. default_type text/html;
  14. content_by_lua "
  15. ngx.print(‘<h2>Runing FPM instances:</h2>‘)
  16. local cmd = [[/bin/ls -1 /var/run/ | grep rgapp- | awk ‘{print \"<p><a href=?sid=\"$1\">\"$1\"</a>\"}‘]]
  17. local f = io.popen(cmd, ‘r‘)
  18. local log = f:read(‘*a‘)
  19. f:close()
  20. ngx.print(log)
  21. ";
  22. }
  23. ...
  24. }
server {
        listen       8360;
        server_name  localhost;

        location /fpm_status {
                if ( $arg_sid = ‘‘ ) {
                        rewrite ^ /fpm_list last;
                }
                include fastcgi_params;
                fastcgi_pass unix:/var/run/$arg_sid/fpm.sock;
        }
        #列出所有正在运行的fpm-sock
        location /fpm_list {
                default_type text/html;
                content_by_lua "
                    ngx.print(‘<h2>Runing FPM instances:</h2>‘)
                    local cmd = [[/bin/ls -1 /var/run/ | grep rgapp- | awk ‘{print \"<p><a href=?sid=\"$1\">\"$1\"</a>\"}‘]]
                    local f = io.popen(cmd, ‘r‘)
                    local log = f:read(‘*a‘)
                    f:close()
                    ngx.print(log)
                 ";
         }
         ...
}

因为应用池里面会有多个应用,所以通过sid参数来参看指定应用的fpm状态。

 

通过地址http://xxx:8360/fpm_status?sid=myapp查看fpm状态

技术分享

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。