zabbix自定义监控网卡流量脚本
2015-11-20 00:09:46
原创作品,允许转载,转载时请务必以超链接形式标明文章原始出处、作者信息和本声明。否则将追究法律责任。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 查看图表形式。
网友评论