zabbix自动发现规则之磁盘IO监控
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了zabbix自动发现规则之磁盘IO监控相关的知识,希望对你有一定的参考价值。
本文章介绍zabbix自动发现规则之磁盘IO监控的案例实践。
主机名:mysql-slave
首先在zabbix_agent下定义一个获取磁盘IO信息的脚本:
cat /etc/zabbix/scripts/disk_io.sh #!/bin/bash Disk=$1 Option=$2 case $Option in rrqm) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $2}' ;; wrqm) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $3}' ;; rps) iostat -dxk 1 2|grep "\b$Disk\b"|tail -1|awk '{print $4}' ;; wps) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $5}' ;; rKBps) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $6}' ;; wKBps) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $7}' ;; avgrq-sz) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $8}' ;; avgqu-sz) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $9}' ;; await) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $10}' ;; svctm) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $11}' ;; util) iostat -dxk 1 2|grep "\b$Disk\b" |tail -1|awk '{print $12}' ;; esac
简单说一下这个iostat的指令:
iostat是I/O statistics(输入/输出统计)的缩写,用来动态监视系统的磁盘操作活动。
iostat[参数][时间][次数]
命令功能
通过iostat方便查看CPU、网卡、tty设备、磁盘、CD-ROM 等等设备的活动情况, 负载信息。
命令参数
-C 显示CPU使用情况
-d 显示磁盘使用情况
-k 以 KB 为单位显示
-m 以 M 为单位显示
-N 显示磁盘阵列(LVM) 信息
-n 显示NFS 使用情况
-p[磁盘] 显示磁盘和分区的情况
-t 显示终端和CPU的信息
-x 显示详细信息
-V 显示版本信息
disk属性值说明:
rrqm/s: 每秒进行 merge 的读操作数目.即 delta(rmerge)/s
wrqm/s: 每秒进行 merge 的写操作数目.即 delta(wmerge)/s
r/s: 每秒完成的读 I/O 设备次数.即 delta(rio)/s
w/s: 每秒完成的写 I/O 设备次数.即 delta(wio)/s
rsec/s: 每秒读扇区数.即 delta(rsect)/s
wsec/s: 每秒写扇区数.即 delta(wsect)/s
rkB/s: 每秒读K字节数.是 rsect/s 的一半,因为每扇区大小为512字节.(需要计算)
wkB/s: 每秒写K字节数.是 wsect/s 的一半.(需要计算)
avgrq-sz:平均每次设备I/O操作的数据大小 (扇区).delta(rsect+wsect)/delta(rio+wio)
avgqu-sz:平均I/O队列长度.即 delta(aveq)/s/1000 (因为aveq的单位为毫秒).
await: 平均每次设备I/O操作的等待时间 (毫秒).即 delta(ruse+wuse)/delta(rio+wio)
svctm: 平均每次设备I/O操作的服务时间 (毫秒).即 delta(use)/delta(rio+wio)
%util: 一秒中有百分之多少的时间用于 I/O 操作,或者说一秒中有多少时间 I/O
定义自动发现规则的key
cat /etc/zabbix/scripts/disk_scan.py import subprocess import json args="cat /proc/diskstats|awk '{print $3}'|grep -E '^[a-z]+$'|sort|uniq 2>/dev/null" t=subprocess.Popen(args,shell=True,stdout=subprocess.PIPE).communicate()[0] disks=[] for disk in t.split('\n'): if len(disk) != 0: disks.append({'{#DISK_NAME}':disk}) print json.dumps({'data':disks},indent=4,separators=(',',':'))
zabbix_agent配置文件
cat /etc/zabbix/zabbix_agentd.conf.d/userparameter_io.conf UserParameter=disk.io[*], sudo /etc/zabbix/scripts/disk_io.sh $1 $2 UserParameter=disk.scan[*], python /etc/zabbix/scripts/disk_scan.py $1
zabbix web界面创建模板
创建模板
设置模板名称,所属组和主机(自定义)
创建Discovery
设置Discovery
注意,这里的key 是在zabbix_agent设置的disk.scan 的disk_scan.py脚本返回值
创建item
设置item
创建完item,如下:
返回mysql-slave主机界面查看item
查看最新数据
创建Graph
查看Graphs
以上是关于zabbix自动发现规则之磁盘IO监控的主要内容,如果未能解决你的问题,请参考以下文章
分布式监控系统Zabbix3.2添加自动发现磁盘IO并注册监控
分布式监控系统Zabbix4.2添加自动发现磁盘IO(实操)