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

2017-10-16  本文已影响301人  jony456123

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

2015-11-20 00:09:46

标签:zabbix监控网卡流量

原创作品,允许转载,转载时请务必以超链接形式标明文章原始出处、作者信息和本声明。否则将追究法律责任。http://msiyuetian.blog.51cto.com/8637744/1714873

之前写了一篇文章主要介绍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

添加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

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

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

上一篇下一篇

猜你喜欢

热点阅读