http://liqingbiao.blog.51cto.com/3044896/1894902
nginx在生产环境中的应用越来越广泛,所以需要对nginx的性能状态做一些监控来发现出来出现的问题。zabbix监控nginx,首先确认nginx的监控指标,主要有:基本活动指标,错误指标,性能指标。
nginx处理流程图具体如下:
注释:Accepts(接受)、Handled(已处理)、Requests(请求数)是一直在增加的计数器。Active(活跃)、Waiting(等待)、Reading(读)、Writing(写)随着请求量而增减
名称 |
描述 |
指标类型 |
Accepts(接受) |
NGINX 所接受的客户端连接数 |
资源: 功能 |
Handled(已处理) |
成功的客户端连接数 |
资源: 功能 |
Active(活跃) |
当前活跃的客户端连接数 |
资源: 功能 |
Dropped(已丢弃,计算得出) |
丢弃的连接数(接受 - 已处理) |
工作:错误* |
Requests(请求数) |
客户端请求数 |
工作:吞吐量 |
NGINX worker 进程接受 OS 的连接请求时 Accepts 计数器增加,而Handled 是当实际的请求得到连接时(通过建立一个新的连接或重新使用一个空闲的)。这两个计数器的值通常都是相同的,如果它们有差别则表明连接被Dropped, 往往这是由于资源限制,比如已经达到 NGINX 的worker_connections的限制。
首先nginx需要配置nginx_status 具体步骤是:在 zabbix agentd客户端上,查看nginx是否加载了with-http_stub_status_module。因为 zabbix 监控nginx是根据nginx的Stub Status模块,抓取Status模块所提供的数据。假如以前没开启,现在想启用StubStatus 模块,在编译nginx 的时候要加上参数with-http_stub_status_module,执行./configure && make就可以了,不用make install,一般情况下都是安装的,具体的安装配置如下
(一)配置nginx
1,查看nginx_status是否开启,查看已开启。
1
2
3
4
5
6
7 |
[root@iZ237lzm354Z scripts]
nginx version: nginx /1 .4.7
built by gcc 4.8.2 20140120 (Red Hat 4.8.2-16) (GCC)
TLS SNI support enabled
configure arguments: --with-http_stub_status_module --with-http_ssl_module --with-pcre
--with-http_realip_module --with-http_image_filter_module
[root@iZ237lzm354Z scripts]
|
2,nginx_status开启的步骤:
1
2
3
4
5
6
7
8
9
10
11
12
13
14 |
[root@iZ237lzm354Z scripts]
server {
listen 80 ;
server_name www.guojinbao.com;
rewrite ^ /invitejoin/ (.*)\.htm[l]?$ /register .shtml?$1 last;
index index.jsp index.html;
root /opt/home ;
location = /nginx-status {
stub_status on;
access_log off;
allow 127.0.0.1;
allow 10.253.12.34;
}
|
3,测试并启动nginx
[root@iZ237lzm354Z scripts]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@iZ237lzm354Z scripts]# /usr/local/nginx/sbin/nginx -s reload
4,用curl来进行测试:
1
2
3
4
5 |
[root@iZ237lzm354Z scripts]
Active connections: 979
server accepts handled requests
756072922 756072922 1136799890
Reading: 0 Writing: 4 Waiting: 975
|
备注:
Active connections –当前活跃的连接数量
server accepts handled requests — 总共处理了756072922个连接 , 成功创建 756072922次握手, 总共处理了1136799890个请求
reading — 读取客户端的连接数.
writing — 响应数据到客户端的数量
waiting — 开启 keep-alive 的情况下,这个值等于 active – (reading+writing), 意思就是 Nginx 已经处理完正在等候下一次请求指令的驻留连接.
(二)配置zabbix_agentd
1,编写脚步来获取nginx的相关信息
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58 |
[root@ittestserver1 opt]
#!/bin/bash
ZBX_REQ_DATA= "$1"
ZBX_REQ_DATA_URL= "$2"
NGINX_STATUS_DEFAULT_URL= "www.guojinbao.com/nginx-status"
WGET_BIN= "/usr/bin/wget"
ERROR_NO_ACCESS_FILE= "-0.9900"
ERROR_NO_ACCESS= "-0.9901"
ERROR_WRONG_PARAM= "-0.9902"
ERROR_DATA= "-0.9903"
if [ ! -z "$ZBX_REQ_DATA_URL" ]; then
URL= "$ZBX_REQ_DATA_URL"
else
URL= "$NGINX_STATUS_DEFAULT_URL"
fi
NGINX_STATS=$($WGET_BIN -q $URL -O - 2> /dev/null )
if [ $? - ne 0 -o -z "$NGINX_STATS" ]; then
echo $ERROR_DATA
exit 1
fi
case $ZBX_REQ_DATA in
active_connections) echo "$NGINX_STATS" | head -1 | cut -f3 -d ' ' ;;
accepted_connections) echo "$NGINX_STATS" | grep -Ev '[a-zA-Z]' | cut -f2 -d ' ' ;;
handled_connections) echo "$NGINX_STATS" | grep -Ev '[a-zA-Z]' | cut -f3 -d ' ' ;;
handled_requests) echo "$NGINX_STATS" | grep -Ev '[a-zA-Z]' | cut -f4 -d ' ' ;;
reading) echo "$NGINX_STATS" | tail -1 | cut -f2 -d ' ' ;;
writing) echo "$NGINX_STATS" | tail -1 | cut -f4 -d ' ' ;;
waiting) echo "$NGINX_STATS" | tail -1 | cut -f6 -d ' ' ;;
*) echo $ERROR_WRONG_PARAM; exit 1;;
esac
exit 0
[root@ittestserver1 opt]
-rw-r--r-x1 root root 1645 2月 4 14:26 /usr/local/zabbix/scripts/nginx-check_performance .sh
|
2,配置zabbix_agentd.conf。启用UserParameter,并配置相关的参数。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24 |
[root@ittestserver1 opt]
UnsafeUserParameters=1
UserParameter=nginx[*], /usr/local/zabbix/scripts/nginx-check_performance .sh "$1"
|
3,重启zabbix_agentd客户端
1
2
3
4 |
[root@zabbix ~]
Shutting down zabbix_agentd: [ OK ]
Starting zabbix_agentd: [ OK ]
[root@zabbix ~]
|
4,在zabbix服务端(server)进行测试。
1
2
3 |
[root@zabbix ~]
0
[root@zabbix ~]
|
(三)在网页上配置nginx模板的相关监控
1,登录zabbix界面,依次点击:配置(configuration)---模板(template)---导入(import)
2,给主机添加模板:选择主机---nginx服务器主机---模板---选择(刚刚导入的nginx性能状态的模板)---添加---更新
3,查看nginx监控的最新数据:监控中---图形---选择相应的监控类型。
备注:
Active :当前活跃的连接数。
Accepts: 接受的请求数
Handled: 处理的请求数(正常服务器响应,这两项应该是可以相等的)
Requests: 客户端处理的请求数。(吞吐量)
Reading: 当接收到请求时,连接离开 Waiting 状态,并且该请求本身使 Reading 状态计数增加。在这种状态下 NGINX 会读取客户端请求首部。请求首部是比较小的,因此这通常是一个快速的操作。
Writing: 请求被读取之后,其使 Writing 状态计数增加,并保持在该状态,直到响应返回给客户端。这意味着,该请求在 Writing 状态时, 一方面 NGINX 等待来自上游系统的结果(系统放在 NGINX “后面”),另外一方面,NGINX 也在同时响应。请求往往会在 Writing 状态花费大量的时间。
Waiting: 活跃的连接也可以处 于 Waiting 子状态,如果有在此刻没有活跃请求的话。新连接可以绕过这个状态并直接变为到 Reading 状态,最常见的是在使用“accept filter(接受过滤器)” 和 “deferred accept(延迟接受)”时,在这种情况下,NGINX 不会接收 worker 进程的通知,直到它具有足够的数据才开始响应。如果连接设置为 keep-alive ,那么它在发送响应后将处于等待状态
本文出自 “清风明月” 博客,请务必保留此出处http://liqingbiao.blog.51cto.com/3044896/1894902
附件下载
http://www.ttlsa.com/zabbix/zabbix-monitor-nginx-performance/
需要使用zabbix监控nginx,首先nginx需要配置ngx_status,如果开启请看凉白开之前的文章《启用nginx status状态详解》
nginx status信息
|
# curl http://127.0.0.1/ngx_status
Active connections: 11921
server accepts handled requests
11989 11989 11991
Reading: 0 Writing: 7 Waiting: 42 |
以上为nginx性能计数,我们除了监控以上数据,还需要监控nginx进程状态,并且配置触发器!
zabbix客户端配置
编写客户端脚本ngx_status.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39 |
#!/bin/bash
# DateTime: 2015-10-25
# AUTHOR:凉白开
# WEBSITE: http://www.ttlsa.com
# Description:zabbix监控nginx性能以及进程状态
# Note:此脚本需要配置在被监控端,否则ping检测将会得到不符合预期的结果
# 文章地址:<span id="sample-permalink" tabindex="-1">http://www.ttlsa.com/zabbix/<span id="editable-post-name" title="临时固定链接,点击可更改这部分。">zabbix-monitor-nginx-performance</span>/</span>
HOST="127.0.0.1"
PORT="80"
# 检测nginx进程是否存在
function ping {
/sbin/pidof nginx | wc -l
}
# 检测nginx性能
function active {
/usr/bin/curl "http://$HOST:$PORT/ngx_status/" 2>/dev/null| grep 'Active' | awk '{print $NF}'
}
function reading {
/usr/bin/curl "http://$HOST:$PORT/ngx_status/" 2>/dev/null| grep 'Reading' | awk '{print $2}'
}
function writing {
/usr/bin/curl "http://$HOST:$PORT/ngx_status/" 2>/dev/null| grep 'Writing' | awk '{print $4}'
}
function waiting {
/usr/bin/curl "http://$HOST:$PORT/ngx_status/" 2>/dev/null| grep 'Waiting' | awk '{print $6}'
}
function accepts {
/usr/bin/curl "http://$HOST:$PORT/ngx_status/" 2>/dev/null| awk NR==3 | awk '{print $1}'
}
function handled {
/usr/bin/curl "http://$HOST:$PORT/ngx_status/" 2>/dev/null| awk NR==3 | awk '{print $2}'
}
function requests {
/usr/bin/curl "http://$HOST:$PORT/ngx_status/" 2>/dev/null| awk NR==3 | awk '{print $3}'
}
# 执行function
$1 |
zabbix客户端配置
将自定义的UserParameter加入配置文件,然后重启agentd,如下:
|
#cat /usr/local/zabbix-3.0.0/etc/zabbix_agentd.conf | grep nginx
UserParameter=nginx.status[*],/usr/local/zabbix-3.0.0/scripts/ngx-status.sh $1
# killall zabbix_agentd
# /usr/local/zabbix-3.0.0/sbin/zabbix_agentd |
zabbix_get获取数据
此步骤可以跳过,但是最好是测试一下,因为通过此命令我们可以检测配置是否正确
|
# /usr/local/zabbix-3.0.0/bin/zabbix_get -s 10.10.1.121 -k 'nginx.status[accepts]'
9570756
# /usr/local/zabbix-3.0.0/bin/zabbix_get -s 10.10.1.121 -k 'nginx.status[ping]'
1 |
在zabbix server服务器上执行如上命令, 10.10.1.121为agentd机器
zabbix web端配置
导入Template App NGINX模板
模板我已经写好了,将会放到附件中。具体导入方式请看前面的文章《zabbix链接及解除模板链接(76)》
Link NGINX模板
到了最后一个阶段,登陆zabbix管理端,link模板到nginx服务器:configuration->hosts->点击nginx所在服务器->点击template->Link new templates输入"Template App NGINX"->Add->最后点击update。
监控效果
zabbix-nginx-status
模板附件下载:zabbix_monitor_nginx_template_ttlsa_com
zabbix_get 找不到命令是因为没有安装zabbix_get
1.yum list all |grep zabbix
返回一个列表,表中出现 zabbix-get.x86_84
2.yum install zabbix-get.x86_64
安装成功!
posted on 2017-02-09 15:03
思月行云 阅读(509)
评论(0) 编辑 收藏 引用 所属分类:
Nginx\Openresty 、
服务器\Ops