使用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的狀態爲空暇的話,那麼這些相關的信息將會以最後請求的服務相關,不然信息取決於當前請求的服務.    
相關文章
相關標籤/搜索