zhouyi 发表于 2019-1-20 09:27:32

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

  

  之前写了一篇文章主要介绍zabbix的搭建使用http://msiyuetian.blog.运维网.com/8637744/1705396
  下面这篇文章主要介绍zabbix自定义监控网卡流量的脚本实现

  

  前期准备
  1、说明
  server ip :192.168.0.115

  client ip :192.168.0.114
  2、开启服务
  因为之前搭建过zabbix环境,这里就不重复了,直接开启服务端的所需服务:
  # /etc/init.d/httpd start
  # /etc/init.d/mysqld start
  # /etc/init.d/zabbix-server start
  # /etc/init.d/zabbix-agent start
  然后在浏览器输入: http://192.168.0.115/zabbix,输入用户名密码后验证登入到zabbix主界面。
  

  客户端也开启zabbix-agent服务:
  # /etc/init.d/zabbix-agent start
  

  以下命令都在客户端执行
  1、修改配置文件
  # 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、编写脚本
  # mkdir /usr/local/sbin/zabbix
  # 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、修改权限
  # chmod a+x /usr/local/sbin/zabbix/net.sh
  

  4、执行脚本前的操作
  
  # touch /tmp/net.log
  # date +%s >>/tmp/neti.log
  # grep eth0 /proc/net/dev |awk '{print $2}' >>/tmp/neti.log
  # date +%s >>/tmp/neto.log
  # grep eth0 /proc/net/dev |awk '{print $10}' >>/tmp/neto.log
  # chown zabbix/tmp/net.log
  # /etc/init.d/zabbix-agent restart
  

  5、执行脚本
  
  # /usr/local/sbin/zabbix/net.sh eth0 in
3                             注意:若报“bc: command not found”,需安装bc:yum install -y bc
  # /usr/local/sbin/zabbix/net.sh eth0 out
2  

  6、检查脚本是否可用(在服务端执行)
  
  # zabbix_get -s 192.168.0.114 -p10050 -k "my.net.if"
3  # zabbix_get -s 192.168.0.114 -p10050 -k "my.net.if"
2  

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

  Configuration --> Hosts --> Items --> Create item
  Name:eth0_net_in
  Type: Zabbix agent

  Key:my.net.if
  Update interval (in sec):30

  Save
  http://s2.运维网.com/wyfs02/M02/76/41/wKioL1ZN9FDB85VbAAEik_2BRng103.jpg
  添加eth0_out:

  
  Configuration --> Hosts --> Items --> Create item
  Name:eth0_net_out
  Type: Zabbix agent
  Key:my.net.if
  Update interval (in sec):30

  Save
  http://s4.运维网.com/wyfs02/M02/76/42/wKiom1ZN9BKx3hoNAAElA1rImys139.jpg
  然后我们在 Monitoring --> Latest data 找到对应的主机名,看到对应的项目
  http://s1.运维网.com/wyfs02/M02/76/41/wKioL1ZN8sqD4pEtAACYsjBYTnQ592.jpg
  也可以点开右边的 Graph 查看图表形式。
  
  

  




页: [1]
查看完整版本: zabbix自定义监控网卡流量脚本