zabbix监控nginx连接状态

zabbix学习笔记:zabbix监控nginx连接状态


zabbix监控nginx

zabbix可以监控nginx的状态,关于一个服务的状态可以查看服务本身的状态(版本号、是否开启),还应该关注服务能力(例如以nginx的负载效果:连接数请求数句柄数)。下面我们使用zabbix监控nginx。


nginx的安装

如果想要查看nginx的服务状态,在对nginx进行源码安装的时候要选中–with-http_stub_status_module模块。

1.解压安装包

[root@server5 mnt]# tar xvf nginx-1.6.2.tar.gz

2.在安装目录下进行模块配置: 
这里写图片描述

3.安装配置的选项: 
这里写图片描述


手动采集nginx数据

安装结束后,在nginx的安装目录(默认是/usr/local/nginx)下我们需要对nginx的主配置文件进行修改,如果nginx能够支持状态信息的显示可以在nginx的版本中进行查看:

1.查看模块是否安装成功: 
这里写图片描述

可以看到已经拥有了–with-http_stub_status_module模块。

2.修改配置文件/usr/loca/nginx/conf/nginx.conf,在http部分添加指定的server服务: 
这里写图片描述

注意:配置只允许192.168.1.0/24网段的人查看nginx的状态,其他网段的人不可以查看。

3.修改完成后启动nginx服务,为了方便期间,可以把/usr/local/nginx/sbin/nginx文件建立软链接到/usr/bin/目录下: 
这里写图片描述

4.开启nginx服务: 
这里写图片描述

5.使用命令采集nginx的状态信息: 
这里写图片描述

6.上述的信息是包括读、写等待以及连接数、请求数等内容,我们需要编写脚本信息进行单独采集。脚本内容如下所示:

#get_nginx_status.sh#nginx信息采集脚本#!/bin/bash#设置初始化信息NGINX_SERVER="192.168.1.108"NGINX_URL="http://${NGINX_SERVER}/status"#设置采集信息的方式function get_active {
    curl -s ${NGINX_URL} | grep "Active" | awk -F ":" '{print $2}'}

function get_reading {
    curl -s ${NGINX_URL} | grep "Reading" | awk -F ":" '{print $2}' | awk -F " " '{print $1}'}

function get_writing {
    curl -s ${NGINX_URL} | grep "Writing" | awk -F ":" '{print $3}' | awk -F " " '{print $1}'}

function get_waiting {
    curl -s ${NGINX_URL} | grep "Waiting" | awk -F ":" '{print $4}' | awk -F " " '{print $1}'}

function get_accepts {
    curl -s ${NGINX_URL} | awk NR==3 | awk -F " " '{print $1}'}

function get_handled {
    curl -s ${NGINX_URL} | awk NR==3 | awk -F " " '{print $2}'}

function get_requests {
    curl -s ${NGINX_URL} | awk NR==3 | awk -F " " '{print $3}'}#获取用户的输入参数得到对应的值case $1 in 
    active)
         get_active
         ;;
    reading)
         get_reading
         ;;
    writing)
         get_writing    
         ;;
    waiting)
         get_waiting
         ;;
    accepts)
         get_accepts 
         ;;
    handled)
         get_handled
         ;;
    requests)
         get_requests    
         ;;
    *)         echo "Usage: $0 {active | reading | writing | waiting | accepts | handled | requests}"esac1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465

7.完成脚本并且进行测试后,需要修改/etc/zabbix/zabbix-agentd.conf文件添加对应的UserParameter:

这里写图片描述

8.在客户端重新启动zabbix-agent服务: 
这里写图片描述

9.在服务端使用zabbix_get命令进行测试,查看是否能够顺利的获取数据,如果次操作可以执行,说明采集状态正常: 
这里写图片描述

我们这里随机对四个数据尽心了测试发现是正常的。


添加到zabbix的监控项items

如果数据的采集都没有问题,那么就可以在web控制台进行items的添加。 
这里写图片描述

我们以nginx.active为例,其他的类似操作: 
这里写图片描述

可以看到所需要的items都已经生成完成,而且这些items都是属于nginx这个应用的: 
这里写图片描述


生成graphs

我们可以对于nginx的服务状态进行可视化操作(生成对应的graphs): 
这里写图片描述

创建screen进行多个graphs的显示: 
这里写图片描述

创建agent1.example.com节点的nginx condition状态的screens完成: 
这里写图片描述

可以看到nginx的accpets、requests、handled状态: 
这里写图片描述


小结:

使用zabbix对于服务的监控步骤都很类似: 
1.首先要手动的获取服务的状态; 
2.然后编写脚本自动获取,然后写入agent的/etc/zabbix/zabbix-agentd.conf文件 
3.在监控服务端zabbix-server进行相关的采集测试,如果能够成功则在web界面进行items和graphs的监控。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章