设为首页 收藏本站
查看: 1296|回复: 0

[经验分享] zabbix监控nginx性能状态

[复制链接]

尚未签到

发表于 2018-11-8 09:05:34 | 显示全部楼层 |阅读模式
  nginx在生产环境中的应用越来越广泛,所以需要对nginx的性能状态做一些监控来发现出来出现的问题。zabbix监控nginx,首先确认nginx的监控指标,主要有:基本活动指标,错误指标,性能指标。
  nginx处理流程图具体如下:
DSC0000.png

  注释: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是否开启,查看已开启。
[root@iZ237lzm354Z scripts]# /usr/local/nginx/sbin/nginx -V  
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开启的步骤:
[root@iZ237lzm354Z scripts]# vim /usr/local/nginx/conf/nginx.conf  
server {
  
                        listen       80 ;
  
                        server_name  www.baidu.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;
  
                             ####zabbix服务器端的IP地址一般为内网IP
  
                               }
  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>  4,用curl来进行测试:
[root@iZ237lzm354Z scripts]# curl www.baidu.com/nginx-status  
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的相关信息
[root@ittestserver1 opt]# vim /usr/local/zabbix/scripts/nginx-check_performance.sh  

  
#!/bin/bash
  
##################################
  
# Zabbix monitoring script
  
#
  
# nginx:
  
# - anything available via nginx stub-status module
  
#
  
##################################
  
# Contact:
  
# vincent.viallet@gmail.com
  
# Zabbix requested parameter
  
ZBX_REQ_DATA="$1"
  
ZBX_REQ_DATA_URL="$2"
  
# Nginx defaults
  
NGINX_STATUS_DEFAULT_URL="www.baidu.com/nginx-status"    #(这里写网站的域名)
  
WGET_BIN="/usr/bin/wget"
  
#
  
# Error handling:
  
# - need to be displayable in Zabbix (avoid NOT_SUPPORTED)
  
# - items need to be of type "float" (allow negative + float)
  
#
  
ERROR_NO_ACCESS_FILE="-0.9900"
  
ERROR_NO_ACCESS="-0.9901"
  
ERROR_WRONG_PARAM="-0.9902"
  
ERROR_DATA="-0.9903" # either can not connect / bad host / bad port
  
# Handle host and port if non-default
  
if [ ! -z "$ZBX_REQ_DATA_URL" ]; then
  
URL="$ZBX_REQ_DATA_URL"
  
else
  
URL="$NGINX_STATUS_DEFAULT_URL"
  
fi
  
# save the nginx stats in a variable for future parsing
  
NGINX_STATS=$($WGET_BIN -q $URL -O - 2> /dev/null)
  
# error during retrieve
  
if [ $? -ne 0 -o -z "$NGINX_STATS" ]; then
  
echo $ERROR_DATA
  
exit 1
  
fi
  
#
  
# Extract data from nginx stats
  
#
  
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]# chmod +x /usr/local/zabbix/scripts/nginx-check_performance.sh
  
-rw-r--r-x1 root root 1645 2月 4 14:26/usr/local/zabbix/scripts/nginx-check_performance.sh
  2,配置zabbix_agentd.conf。启用UserParameter,并配置相关的参数。
[root@ittestserver1 opt]# vim /usr/local/zabbix/etc/zabbix_agentd.conf  
####### USER-DEFINED MONITORED PARAMETERS #######
  
### Option: UnsafeUserParameters
  
#       Allow all characters to be passed in arguments to user-defined parameters.
  
#       The following characters are not allowed:
  
#       \ ' " ` * ? [ ] { } ~ $ ! & ; ( ) < > | # @
  
#       Additionally, newline characters are not allowed.
  
#       0 - do not allow
  
#       1 - allow
  
#
  
# Mandatory: no
  
# Range: 0-1
  
# Default:
  
# UnsafeUserParameters=0
  
UnsafeUserParameters=1
  
### Option: UserParameter
  
#       User-defined parameter to monitor. There can be several user-defined parameters.
  
#       Format: UserParameter=,
  
#       See 'zabbix_agentd' directory for examples.
  
#
  
# Mandatory: no
  
# Default:
  
# UserParameter=
  
UserParameter=nginx
  • ,/usr/local/zabbix/scripts/nginx-check_performance.sh "$1"
      3,重启zabbix_agentd客户端
    [root@zabbix ~]# /etc/init.d/zabbix_agentd restart  
    Shutting down zabbix_agentd:                               [  OK  ]
      
    Starting zabbix_agentd:                                    [  OK  ]
      
    [root@zabbix ~]#
      4,在zabbix服务端(server)进行测试。
    [root@zabbix ~]# zabbix_get -s 10.253.17.20 -p 10050 -k "nginx[reading]"  
    0
      
    [root@zabbix ~]#
      (三)在网页上配置nginx模板的相关监控
      1,登录zabbix界面,依次点击:配置(configuration)---模板(template)---导入(import)
    DSC0001.png

      2,给主机添加模板:选择主机---nginx服务器主机---模板---选择(刚刚导入的nginx性能状态的模板)---添加---更新
    DSC0002.png

      3,查看nginx监控的最新数据:监控中---图形---选择相应的监控类型。
    DSC0003.png

      备注:
      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、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
    2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
    3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
    4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
    5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
    6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
    7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
    8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

    所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-632208-1-1.html 上篇帖子: Docker手动构建 nginx+py3+uwsgi环境 下篇帖子: Bind+Nginx实现负载均衡
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    扫码加入运维网微信交流群X

    扫码加入运维网微信交流群

    扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

    扫描微信二维码查看详情

    客服E-mail:kefu@iyunv.com 客服QQ:1061981298


    QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


    提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


    本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



    合作伙伴: 青云cloud

    快速回复 返回顶部 返回列表