|
上篇写了一个zabbix_系统IO监控,但每次都需要手动加,比较费劲,监控项跟图形都只能一个一个加
附上篇博客地址: http://xiong51.blog.运维网.com/5239058/1947663
这次使用zabbix_自动发现的模式来搞一次,
大概思路,
1、在zabbix客户端先配置iostat最新数据,
1.1、不能直接使用iostat,因为它的数据一直会固定不动,使用iostst -xdkt 5 3 (5秒3次)
1.2、 定义好脚本之后需要使用crontab配置每1分钟或者30秒更新一次数据,直接输送到文件就成
2、写一个自动发现的脚本,发现iostat有几个磁盘,格式必须为JSON,key值必须大写
2.1、 小写会出现 这个 Cannot create item: item with the same key “custom.vfs.dev.read.ops `xxxxxx` already exists
2.2、 避免出现坑,配置完成之后在zabbix服务端上运行,出现下图的结果说明脚本运行正常
2.3、 在测试之前,必须在zabbix客户端的配置文件中加一行,io.dis为自己定义的键
UserParameter=io.dis.status
,/usr/local/zabbix/scripts/discovery_iostat_disk.sh
3、最后在弄一个脚本,配置你想要监控的项就成
rrqm/s wrqm/s r/s w/s rkB/s wkB/s avgrq-sz avgqu-sz await r_await w_await svctm %util
各项值的详解
rrqm/s: 每秒进行 merge 的读操作数目。即 rmerge/s
wrqm/s: 每秒进行 merge 的写操作数目。即 wmerge/s
r/s: 每秒完成的读 I/O 设备次数。即 rio/s
w/s: 每秒完成的写 I/O 设备次数。即 wio/s
rsec/s: 每秒读扇区数。即 rsect/s
wsec/s: 每秒写扇区数。即 wsect/s
rkB/s: 每秒读K字节数。是 rsect/s 的一半,因为每扇区大小为512字节。
wkB/s: 每秒写K字节数。是 wsect/s 的一半。
avgrq-sz: 平均每次设备I/O操作的数据大小 (扇区)。
avgqu-sz: 平均I/O队列长度。
await: 平均每次设备I/O操作的等待时间 (毫秒)。
svctm: 平均每次设备I/O操作的服务时间 (毫秒)。
%util: 一秒中有百分之多少的时间用于 I/O 操作,即被io消耗的cpu百分比
4、 附上脚本一共四个 所有脚本都需要7的权限 rwx 使用zabbix用户
#!/bin/bash
#
# Name:service 取出io数据用于分析
# Version Number:1.01
# Type: 取出I/O数据
# Language:bash shell
# Date:2017-08-07
# Author:xiong
iostat -xdkt 5 3 > /tmp/io.txt
times=`date +%H":"%M":"%S`
# 取出最后一次iostat更新的数据,为最新数据,将最新的数据更新至/tmp/2.txt 不输出
grep "$times" -A 100 /tmp/io.txt > /tmp/io2.txt#!/bin/bash
#
# Name:service 自动发现io_磁盘
# Version Number:1.01
# Type: 自动发现io_磁盘
# Language:bash shell
# Date:2017-08-07
# Author:xiong
disk=(`awk '{print $1}' /tmp/io2.txt | sed -e "1,2d"`)
length=${#disk[@]}
printf "{\n"
printf "\t\"data:\"[\n"
for ((i=0;i |
|
|