轉自http://www.ttlsa.com/php/use-php-fpm-status-page-detail/
php-fpm和nginx一樣內建了一個狀態頁,對于想了解php-fpm的狀態以及監控php-fpm非常有幫助。為了后續的zabbix監控,我們需要先了解php-fpm狀態頁是怎么回事。
- 啟用php-fpm狀態功能
# cat /usr/local/php-5.5.10/etc/php-fpm.conf | grep status_path
pm.status_path = /status
默認情況下為/status,當然也可以改成其他的,例如/ttlsa_status等等。
- nginx配置
在默認主機里面加上location或者你希望能訪問到的主機里面。
server {
listen *:80 default_server;
server_name _;
location ~ ^/(status|ping)$
{
include fastcgi_params;
fastcgi_pass 127.0.0.1:9000;
fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
}
}
- 重啟nginx/php-fpm
# service nginx restart
# service php-fpm restart
- 打開status頁面
# curl http://www.ttlsa.com/status
pool: www
process manager: dynamic
start time: 14/May/2014:22:40:15 +0800
start since: 58508
accepted conn: 33
listen queue: 0
max listen queue: 8
listen queue len: 0
idle processes: 2
active processes: 1
total processes: 3
max active processes: 5
max children reached: 0
slow requests: 2091
php-fpm status詳解
pool – fpm池子名稱,大多數為www
process manager – 進程管理方式,值:static, dynamic or ondemand. dynamic
start time – 啟動日期,如果reload了php-fpm,時間會更新
start since – 運行時長
accepted conn – 當前池子接受的請求數
listen queue – 請求等待隊列,如果這個值不為0,那么要增加FPM的進程數量
max listen queue – 請求等待隊列最高的數量
listen queue len – socket等待隊列長度
idle processes – 空閑進程數量
active processes – 活躍進程數量
total processes – 總進程數量
max active processes – 最大的活躍進程數量(FPM啟動開始算)
max children reached - 大道進程最大數量限制的次數,如果這個數量不為0,那說明你的最大進程數量太小了,請改大一點。
slow requests – 啟用了php-fpm slow-log,緩慢請求的數量php-fpm其他參數
php-fpm狀態頁比較個性化的一個地方是它可以帶參數,可以帶參數json、xml、html并且前面三個參數可以分別和full做一個組合。
6.1 json
# curl http://127.0.0.1/status?json {"pool":"www","process manager":"dynamic","start time":1400078415,"start since":59624,"accepted conn":27,"listen queue":0,"max listen queue":8,"listen queue len":0,"idle processes":2,"active processes":1,"total processes":3,"max active processes":5,"max children reached":0,"slow requests":2145}
6.4 full
```
# curl http://127.0.0.1/status?full
pool: www
process manager: dynamic
start time: 14/May/2014:22:40:15 +0800
start since: 59695
accepted conn: 1
listen queue: 0
max listen queue: 8
listen queue len: 0
idle processes: 2
active processes: 1
total processes: 3
max active processes: 5
max children reached: 0
slow requests: 2148
************************
pid: 29050
state: Idle
start time: 15/May/2014:15:09:32 +0800
start since: 338
requests: 62
request duration: 1025585
request method: GET
request URI: /index.php
content length: 0
user: -
script: /data/site/www.ttlsa.com/index.php
last request cpu: 45.83
last request memory: 24903680
.....省略幾個PID....
```
6.5 full詳解
pid – 進程PID,可以單獨kill這個進程. You can use this PID to kill a long running process.
state – 當前進程的狀態 (Idle, Running, …)
start time – 進程啟動的日期
start since – 當前進程運行時長
requests – 當前進程處理了多少個請求
request duration – 請求時長(微妙)
request method – 請求方法 (GET, POST, …)
request URI – 請求URI
content length – 請求內容長度 (僅用于 POST)
user – 用戶 (PHP_AUTH_USER) (or ‘-’ 如果沒設置)
script – PHP腳本 (or ‘-’ if not set)
last request cpu – 最后一個請求CPU使用率。
last request memorythe - 上一個請求使用的內存
- 完成php-fpm狀態頁非常使用,使用zabbix或者nagios監控可以考慮使用xml或者默認方式。用web的話,推薦使用html,表格會比較清晰。