您的位置:首页 > 运维架构

zabbix自定义监控脚本

2016-06-27 11:11 375 查看
思路:监控两段时间的差值除以两段时间的时间差值等于平均值
1. 在客户端修改配置文件 /etc/zabbix/zabbix_agentd.conf
需要改动两个地方:
(1)UnsafeUserParameters=1
(2)UserParameter=my.net.if[*],/usr/local/sbin/zabbix/net.sh $1 $2 #其中UserParameter用来自定义键值,(类似于net.if.in),自己写的脚本往往会有参数,所以需要加[*],这是固定写法,如果脚本压根就没有什么参数,那么这个就省了。逗号后面就是我们写的脚本的路径了,再后面就是要用到的参数,有几个就写几。
如果有多个自定义脚本就写多行
2. 在脚本执行前,需要先做一个操作
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
3、编辑脚本
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

4. 检查脚本是否可用
添加执行权限chmod a+x /usr/local/sbin/zabbix/net.sh
执行 sh /usr/local/sbin/zabbix/net.sh ech0 in查看流量,如果查看的流量为负数,则脚本写的有问题
重启客户端/etc/init.d/zabbix-agent restart
在服务端执行
zabbix_get -s 10.10.13.247 -p10050 -k "my.net.if[eth0,out]" #eth0,out即为参数

5. 如果可以返回数值说明没问题了,接着在浏览器里面配置
组态 --> 主机 --> 项目 --> 创建监控项
名称 “eth0_net_in”
类型默认“zabbix代理”
键值 "my.net.if[eth0,in]"
数据更新间隔 60
存档
6、在monitor-lastdata查看有没有最新的数值
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息