免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 788 | 回复: 0
打印 上一主题 下一主题

[系统管理] zabbix应用实战--Nginx监控详解 [复制链接]

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-01-17 18:19:30
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-12-31 18:12 |只看该作者 |倒序浏览

一、nginx监控说明:

1、监控指标:

基本活动指标

错误指标

性能指标

2、nginx 处理请求流程(图形):

                                       


注释:Accepts(接受)、Handled(已处理)、Requests(请求数)是一直在增加的计数器。Active(活跃)、Waiting(等待)、Reading(读)、Writing(写)随着请求量而增减


名称
描述

Accepts(接受)
NGINX 所接受的客户端连接数
资源: 功能

Handled(已处理)
成功的客户端连接数
资源: 功能

Active(活跃)
当前活跃的客户端连接数
资源: 功能

Dropped(已丢弃,计算得出)
丢弃的连接数(接受 – 已处理)
工作:错误*

Requests(请求数)
客户端请求数
工作:吞吐量

NGINX worker 进程接受 OS 的连接请求时 Accepts 计数器增加,而Handled 是当实际的请求得到连接时(通过建立一个新的连接或重新使用一个空闲的)。这两个计数器的值通常都是相同的,如果它们有差别则表明连接被Dropped, 往往这是由于资源限制,比如已经达到 NGINX 的worker_connections的限制。

二、监控配置:

1、主要是基于nginx的status模块.在编译安装时候加上--with-http_stub_status_module.模块编译

2、修改配置文件开启nginx_status:

  location /nginx_status {

stub_status on;

access_log off;

allow 192.168.1.100;  访问IP

deny all;

}

3、打开web 监控:


注释:

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 ,那么它在发送响应后将处于等待状态


三、添加监控:


1、添加脚本:

[root@BJ-monitor-h-01 scripts]# cat nginx_status.sh

#!/bin/bash

# Script to fetch nginx statuses for tribily monitoring systems

# Author: xiaoluo

function active {

/usr/bin/curl "http://192.168.10.234/status" 2>/dev/null| grep 'Active' | awk '{print $NF}'

}

function reading {

/usr/bin/curl "http://192.168.10.234/status" 2>/dev/null| grep 'Reading' | awk '{print $2}'

}

function writing {

/usr/bin/curl "http://192.168.10.234/status" 2>/dev/null| grep 'Writing' | awk '{print $4}'

}

function waiting {

/usr/bin/curl "http://192.168.10.234/status" 2>/dev/null| grep 'Waiting' | awk '{print $6}'

}

function accepts {

/usr/bin/curl "http://192.168.10.234/status" 2>/dev/null| awk NR==3 | awk '{print $1}'

}

function handled {

/usr/bin/curl "http://192.168.10.234/status" 2>/dev/null| awk NR==3 | awk '{print $2}'

}

function requests {

/usr/bin/curl "http://192.168.10.234/status" 2>/dev/null| awk NR==3 | awk '{print $3}'

}

# Run the requested function

$1


2、zabbix配置文件添加自定义监控:

UserParameter=nginx

  • ,/usr/local/zabbix/scripts/nginx_status.sh $1



    3、web界面添加item即可,以链接状态为例(类似的添加即可):



       总结,导出nginx监控添加已经完成。

    运维平台开源地址:https://github.com/roncoo/roncoo-cmdb


  • 您需要登录后才可以回帖 登录 | 注册

    本版积分规则 发表回复

      

    北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
    未成年举报专区
    中国互联网协会会员  联系我们:huangweiwei@itpub.net
    感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

    清除 Cookies - ChinaUnix - Archiver - WAP - TOP