之前写了一篇文章主要介绍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 |
[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 查看图表形式。