使用php-fpm状态页观察当前的php-fpm状态

    对于php-fpm的參数设置,很是多状况下有这种疑问,就是内置的几个參数好比pm.max_children,pm.start_servers等这几个參数究竟该设置最多为多少才合适。事实上这几个參数每每取决于当前的链接数状况,而大多数状况下,咱们很是难判定当前的链接数状况对于咱们的pm等几个參数是否合适。因此借助于php-fpm状态页可以很是方便的告诉咱们这几个參数的设置是否合适。     要开启php-fpm的状态页事实上很是easy在nginx的配置文件里增长:     location /status {             auth_basic "status page";             auth_basic_user_file /etc/nginx/login;             fastcgi_index  index.php;             fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;             include fastcgi_params;             fastcgi_pass 127.0.0.1:9000;         }     上面的auth_basic和auth_basic_user_file不是必须的,但这些都是敏感信息,通常不能让其余人看到,因此这里作了认证。在php-fpm.conf中打开:     pm.status_path = /status          而后在浏览器中打开localhost/status就可以查看到当前的状态信息了     pool:                 www     process manager:      dynamic     start time:           17/Aug/2014:15:25:50 -0400     start since:          7702     accepted conn:        1486     listen queue:         0     max listen queue:     129     listen queue len:     128     idle processes:       9     active processes:     1     total processes:      10     max active processes: 20     max children reached: 2     slow requests:        0     如下介绍每个參数的做用:     pool:php-fpm池的名称,通常都是应该是www     process manage:进程的管理方法,php-fpm支持三种管理方法,各自是static,dynamic和ondemand,普通状况下都是dynamic     start time:php-fpm启动时候的时间,不管是restart或者reload都会更新这里的时间     start since:php-fpm自启动起来通过的时间,默以为秒     accepted conn:当前接收的链接数     listen queue:在队列中等待链接的请求个数,假设这个数字为非0,那么最好添加进程的fpm个数     max listen queue:从fpm启动以来,在队列中等待链接请求的最大值     listen queue len:等待链接的套接字队列大小     idle processes:空暇的进程个数     active processes:活动的进程个数     total processes:总共的进程个数     max active processes:从fpm启动以来,活动进程的最大个数,假设这个值小于当前的max_children,可以调小此值     max children reached:当pm尝试启动不少其它的进程,却因为max_children的限制,没有启动不少其它进程的次数。假设这个值非0,那么可以适当添加fpm的进程数     slow requests:慢请求的次数,通常假设这个值未非0,那么可能会有慢的php进程,通常一个很差的mysql查询是最大的祸首。     假设想看到更加具体的信息,可以使用localhost/status?full查看每个子进程更加额外的信息,拿当中的一个子进程来讲明:     pid:                  6917     state:                Idle     start time:           17/Aug/2014:15:27:46 -0400     start since:          8399     requests:             35     request duration:     69295     request method:       GET     request URI:          /member.php?mod=logging&action=login&infloat=yes&frommessage&inajax=1&ajaxtarget=messagelogin     content length:       0     user:                 -     script:               /usr/local/nginx/html/member.php     last request cpu:     72.16     last request memory:  3145728          这里的都比較好理解,主要看下content length和user     content length:这里记录的是POST请求的内容长度.     user:假设设置了PHP_AUTH_USER就会显示对于的值,不然显示为0.          这里需要注意的是假设state的状态为空暇的话,那么这些相关的信息将会以最后请求的服务相关,不然信息取决于当前请求的服务.    
相关文章
相关标签/搜索