zabbix自定义脚本

这个脚本的思路,自定义一个key,然后就是通过查看文件 /proc/net/dev  里面的数值,来计算实时网卡流量,其实我算的是一个平均值。分为进和出。如果这个脚本每隔1分钟执行一次,那么算出来的流量值就是1分钟的平均值。最终得到网卡流量趋势图。

成都创新互联公司是一家集网站设计制作、成都网站建设、网站页面设计、网站优化SEO优化为一体的专业网站建设公司,已为成都等多地近百家企业提供网站建设服务。追求良好的浏览体验,以探求精品塑造与理念升华,设计最适合用户的网站页面。 合作只是第一步,服务才是根本,我们始终坚持讲诚信,负责任的原则,为您进行细心、贴心、认真的服务,与众多客户在蓬勃发展的市场环境中,互促共生。

客户端操作

# vim /etc/zabbix/zabbix_agentd.conf

# UnsafeUserParameters=0 取消注释并修改为1,在下面增加一行

UserParameter=my.net.if[*],/usr/local/sbin/zabbix/net.sh $1 $2

my.net.if[相当于命令名字,他是key

其中UserParameter用来自定义键值,(类似于net.if.in),自己写的脚本往往会有参数,[*] 表示他有自己的参数,所以需要加[*],这是固定写法,如果脚本压根就没有什么参数,那么这个就省了。逗号后面就是我们写的脚本的路径了,再后面就是要用到的参数,有几个就写几。如果没有参数,后面的 $1 $2 还有前面的 [*] 就都可以省略。

不足之处:

脚本需要工作中不断的进行改进。

并没有针对每个网卡设定单独的文件,所有网卡使用同一个日志文件

# 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

----------------------------------------------------------------------------------------------------------------------------

详解

eth=$1 # 第一个参数,网卡名字,脚本并不针对特定的网卡,可以监控很多网卡,监控进和出

io=$2 # 第二个参数,并非io,而是in or out 的简写

net_file="/proc/net/dev" #最关键文件,网卡流量就是从这个文件获得的。这个脚本的思路,就是通过查看文件 /proc/net/dev  里面的数值,来计算实时网卡流量,其实我算的是一个平均值。分为进和出。如果这个脚本每隔1分钟执行一次,那么算出来的流量值就是1分钟的平均值。

n_new=`grep "$eth" $net_file|awk '{print $2}'` # 通过上面的文件,获得最新的一个数值

n_old=`tail -1 /tmp/neti.log` # 查看上一次网卡流量多少

n=`echo "$n_new-$n_old"|bc` # n 是两者的差值(上面二个新老网卡流量做减法)

d_new=`date +%s` # 记录当前的时间戳

d_old=`tail -2 /tmp/neti.log|head -1` # 查找上一次的时间戳

d=`echo "$d_new-$d_old"|bc` # d 是两个时间间隔

if_net=`echo "$n/$d"|bc` # 求平均值

echo $if_net # 输出平均值

date +%s>>/tmp/neti.log # 当前时间戳输入到日志中

grep "$eth" $net_file|awk '{print $2}'>>/tmp/neti.log # 当前流量输入到日志中

----------------------------------------------------------------------------------------------------------------------------

值与上一次减一下然后除一下,求一个平均值

# chmod a+x /usr/local/sbin/zabbix/net.sh # 更改权限

执行操作执行,先创建脚本里面要使用的目录和文件

# touch /tmp/net[io].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[io].log

执行脚本检测:

# /usr/local/sbin/zabbix/net.sh eth0 in

# /usr/local/sbin/zabbix/net.sh eth0 out

此时检测 eth2 或者其他网卡的流量会报错,因为执行脚本之前,grep 过滤出来的是 eth0 的流量,这里直接使用 eth2 得出的数字肯定是错误的。所以,如果是想检测 eth2 的流量,那么在 grep 和 touch 的时候,就应该使用 eth2。

# /etc/init.d/zabbix-agent restart

服务端

# zabbix_get -s 192.168.32.150 -p10050 -k "my.net.if[eth0,out]"查看out网卡流量,单位字节

395

# zabbix_get -s 192.168.32.150 -p10050 -k "my.net.if[eth0,in]" 查看in网卡流量,单位字节

308

WEB端

zabbix 自定义脚本

下图的 key 只能手写,并不能选择。

创建eth0_net_in和eth0_net_out

查看是否添加成功

需求:统计每分钟的在线人数,通过数据库获得在线人数。

思路:

1、客户端增加 key

UserParameter=my.online,/usr/local/sbin/zabbix/online.sh

#因为这个需求没有参数,所以去掉参数选项

2、编写脚本

从数据库里面获得每分钟的在线人数

3、测试

服务端进行操作

# zabbix_get -s 192.168.32.150 -p10050 -k "my.online"

如果返回了参数,那么就代表成功。


当前标题:zabbix自定义脚本
文章来源:http://myzitong.com/article/gdiojs.html