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,如需转载请自行联系原作者






相关文章
|
27天前
|
监控 Java Shell
监控堆外第三方监控工具Zabbix
监控堆外第三方监控工具Zabbix
37 5
|
7月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
7月前
|
数据采集 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
282 4
|
24天前
|
监控 安全 前端开发
使用 Zabbix 监控堆外应用
使用 Zabbix 监控堆外应用
41 9
|
23天前
|
监控 数据可视化 Java
zabbix全面的监控能力
zabbix全面的监控能力
49 7
|
4月前
|
监控 安全 Linux
在Linux中,zabbix如何监控脑裂?
在Linux中,zabbix如何监控脑裂?
|
1月前
|
SQL 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
105 7
|
2月前
|
SQL 监控 数据库
OceanBase社区版可以通过Zabbix监控
【10月更文挑战第5天】随着OceanBase社区版的广泛应用,企业纷纷采用这一高性能、高可用的分布式数据库系统。为了确保系统的稳定运行,使用成熟的Zabbix监控工具进行全面监控至关重要。本文通过具体示例介绍了如何配置Zabbix监控OceanBase,包括安装配置、创建监控模板和监控项、编写脚本、设置触发器及图形展示等步骤,帮助读者快速上手,及时发现并解决问题,确保业务始终处于最佳状态。
91 2
|
3月前
|
监控 关系型数据库 MySQL
zabbix agent集成percona监控MySQL的插件实战案例
这篇文章是关于如何使用Percona监控插件集成Zabbix agent来监控MySQL的实战案例。
84 2
zabbix agent集成percona监控MySQL的插件实战案例
|
4月前
|
SQL 监控 分布式数据库
【解锁数据库监控的神秘力量!】OceanBase社区版与Zabbix的完美邂逅 —— 揭秘分布式数据库监控的终极奥秘!
【8月更文挑战第7天】随着OceanBase社区版的普及,企业广泛采用这一高性能、高可用的分布式数据库。为保障系统稳定,使用成熟的Zabbix监控工具对其进行全方位监控至关重要。本文通过实例介绍如何在Zabbix中配置监控OceanBase的方法,包括创建监控模板、添加监控项(如TPS)、设置触发器及图形展示,并提供示例脚本帮助快速上手。通过这些步骤,可以有效监控OceanBase状态,确保业务连续性。
110 0

推荐镜像

更多