zabbix自定义监控网卡流量脚本

简介:

之前写了一篇文章主要介绍zabbix的搭建使用http://msiyuetian.blog.51cto.com/8637744/1705396

下面这篇文章主要介绍zabbix自定义监控网卡流量的脚本实现


前期准备


1、说明

server ip :192.168.0.115

client ip :192.168.0.114

2、开启服务

因为之前搭建过zabbix环境,这里就不重复了,直接开启服务端的所需服务:

[root@server ~]# /etc/init.d/httpd start

[root@server ~]# /etc/init.d/mysqld start

[root@server ~]# /etc/init.d/zabbix-server start

[root@server ~]# /etc/init.d/zabbix-agent start

然后在浏览器输入: http://192.168.0.115/zabbix,输入用户名密码后验证登入到zabbix主界面。


客户端也开启zabbix-agent服务:

[root@client ~]# /etc/init.d/zabbix-agent start


以下命令都在客户端执行


1、修改配置文件

[root@client ~]# vim /etc/zabbix/zabbix_agentd.conf   //改动两个地方

UnsafeUserParameters=1

UserParameter=my.net.if[*], /usr/local/sbin/zabbix/net.sh $1 $2

说明:UserParameter用来自定义键值,(类似于net.if.in),自己写的脚本往往会有参数,所以需要加,这是固定写法,如果脚本压根就没有什么参数,那么这个就省了。逗号后面就是我们写的脚本的路径了,再后面就是要用到的参数,有几个就写几。


2、编写脚本

[root@client ~]# mkdir /usr/local/sbin/zabbix

[root@client ~]# vim /usr/local/sbin/zabbix/net.sh

#!/bin/bash
eth=$1
io=$2
net_file="/proc/net/dev"
if [ $2 == "in" ]
then
    n_new=`grep "$eth" $net_file|awk '{print $2}'`
    n_old=`tail -1 /tmp/neti.log`
    n=`echo "$n_new-$n_old"|bc`
    d_new=`date +%s`
    d_old=`tail -2 /tmp/neti.log|head -1`
    d=`echo "$d_new-$d_old"|bc`
    if_net=`echo "$n/$d"|bc`
    echo $if_net
    date +%s>>/tmp/neti.log
    grep "$eth" $net_file|awk '{print $2}'>>/tmp/neti.log
elif [ $2 == "out" ]
then
    n_new=`grep "$eth" $net_file|awk '{print $10}'`
    n_old=`tail -1 /tmp/neto.log`
    n=`echo "$n_new-$n_old"|bc`
    d_new=`date +%s`
    d_old=`tail -2 /tmp/neto.log|head -1`
    d=`echo "$d_new-$d_old"|bc`
    if_net=`echo "$n/$d"|bc`
    echo $if_net
    date +%s>>/tmp/neto.log
    grep "$eth" $net_file|awk '{print $10}'>>/tmp/neto.log
else
    echo 0
fi

说明:脚本的思路就是通过查看文件 /proc/net/dev 里面的数值,来计算实时网卡流量,其实我算的是一个平均值。分为进和出。如果这个脚本每隔1分钟执行一次,那么算出来的流量值就是1分钟的平均值。


3、修改权限

[root@client ~]# chmod a+x /usr/local/sbin/zabbix/net.sh


4、执行脚本前的操作

[root@client ~]# touch /tmp/net[io].log

[root@client ~]# date +%s >>/tmp/neti.log

[root@client ~]# grep eth0 /proc/net/dev |awk '{print $2}' >>/tmp/neti.log

[root@client ~]# date +%s >>/tmp/neto.log

[root@client ~]# grep eth0 /proc/net/dev |awk '{print $10}' >>/tmp/neto.log

[root@client ~]# chown zabbix  /tmp/net[io].log

[root@client ~]# /etc/init.d/zabbix-agent restart


5、执行脚本

[root@client ~]# /usr/local/sbin/zabbix/net.sh eth0 in

3                           

注意:若报“bc: command not found”,需安装bc:yum install -y bc

[root@client ~]# /usr/local/sbin/zabbix/net.sh eth0 out

2


6、检查脚本是否可用(在服务端执行)

[root@server ~]# zabbix_get -s 192.168.0.114 -p10050 -k "my.net.if[eth0,in]"

3

[root@server ~]# zabbix_get -s 192.168.0.114 -p10050 -k "my.net.if[eth0,out]"

2


7、在zabbix网页上配置

首先找到对应添加的主机,这里我用上篇文章做实验时候添加的主机,名为tpp,这里只修改以下几处:

添加eth0_in:

Configuration --> Hosts --> Items --> Create item

Name:eth0_net_in

Type: Zabbix agent

Key:my.net.if[eth0,in]

Update interval (in sec):30

Save

wKioL1ZN9FDB85VbAAEik_2BRng103.jpg

添加eth0_out:

Configuration --> Hosts --> Items --> Create item

Name:eth0_net_out

Type: Zabbix agent

Key:my.net.if[eth0,out]

Update interval (in sec):30

Save

wKiom1ZN9BKx3hoNAAElA1rImys139.jpg

然后我们在 Monitoring --> Latest data 找到对应的主机名,看到对应的项目

wKioL1ZN8sqD4pEtAACYsjBYTnQ592.jpg

也可以点开右边的 Graph 查看图表形式。



      本文转自 M四月天 51CTO博客,原文链接:http://blog.51cto.com/msiyuetian/1714873,如需转载请自行联系原作者






相关文章
|
3月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
4月前
|
数据采集 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
77 4
|
4月前
|
监控 关系型数据库 机器人
小白带你学习linux的监控平台zabbix
小白带你学习linux的监控平台zabbix
136 0
|
7月前
|
监控 前端开发 JavaScript
Zabbix分布式监控Web监控
Zabbix分布式监控Web监控
82 0
|
6月前
|
监控 关系型数据库 MySQL
企业实战(8)CentOS 6.8安装Zabbix-agent 5.0监控主机性能与Mysql数据库
企业实战(8)CentOS 6.8安装Zabbix-agent 5.0监控主机性能与Mysql数据库
|
1月前
|
数据采集 监控 数据库
请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
【2月更文挑战第25天】请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
25 2
|
6月前
|
监控
zabbix如何添加自定义监控项
zabbix如何添加自定义监控项
261 0
|
2月前
|
监控 Cloud Native 关系型数据库
使用 Grafana 统一监控展示 - 对接 Zabbix
使用 Grafana 统一监控展示 - 对接 Zabbix
|
4月前
|
监控 Docker 容器
Zabbix【部署 03】zabbix-agent2安装配置使用(zabbix-agent2监控docker实例分享)
Zabbix【部署 03】zabbix-agent2安装配置使用(zabbix-agent2监控docker实例分享)
236 0
|
4月前
|
监控 Java
Zabbix【部署 02】Zabbix-Java-Gateway安装配置使用(使用Zabbix-Java-Gateway通过JMX监控Java应用程序实例分享)
Zabbix【部署 02】Zabbix-Java-Gateway安装配置使用(使用Zabbix-Java-Gateway通过JMX监控Java应用程序实例分享)
89 0

推荐镜像

更多