nginx和php-fpm一样内建了一个状态页,对于想了解nginx的状态以及监控nginx非常有帮助。为了后续的zabbix监控,我们需要先了解nginx状态页是怎么回事。
1. 启用nginx status配置
在默认主机里面加上location或者你希望能访问到的主机里面。
1
2
3
4
5
6
7
8
9
10
11
|
server {
listen *:80 default_server;
server_name _;
location /ngx_status
{
stub_status on;
access_log off;
#allow 127.0.0.1;
#deny all;
}
}
|
2. 重启nginx
请依照你的环境重启你的nginx
1
|
# service nginx restart
|
3. 打开status页面
1
|
# curl http://127.0.0.1/ngx_status
|
1
2
3
4
|
Active connections: 11921
server accepts handled requests
11989 11989 11991
Reading: 0 Writing: 7 Waiting: 42
|
4. nginx status详解
- active connections – 活跃的连接数量
- server accepts handled requests — 总共处理了11989个连接 , 成功创建11989次握手, 总共处理了11991个请求
- reading — 读取客户端的连接数.
- writing — 响应数据到客户端的数量
- waiting — 开启 keep-alive 的情况下,这个值等于 active – (reading+writing), 意思就是 Nginx 已经处理完正在等候下一次请求指令的驻留连接.
脚本中,以下指令指定启用获取Nginx工作状态的功能。
1
2
3
4
5
6
|
location /NginxStatus {
stub_status on;
access_log logs /NginxStatus .log;
auth_basic "NginxStatus" ;
}
|
1
2
3
4
5
|
Active connections: 2
server accepts handled requests
24 24 129
Reading: 1 Writing: 1 Waiting: 0
|
- Active connections: 对后端发起的活动连接数.
- Server accepts handled requests: Nginx总共处理了24个连接,成功创建24次握手(证明中间没有失败的),总共处理了129个请求.
- Reading: Nginx 读取到客户端的Header信息数.
- Writing: Nginx 返回给客户端的Header信息数.
- Waiting: 开启keep-alive的情况下,这个值等于 active – (reading + writing),意思就是Nginx已经处理完成,正在等候下一次请求指令的驻留连接.
所以,在访问效率高,请求很快被处理完毕的情况下,Waiting数比较多是正常的.如果reading +writing数较多,则说明并发访问量。