一、场景说明:
需要使用Zabbix监控服务器上各个磁盘的I/O使用率,当zabbix自身带的item无法满足我们的时候,则需自定义item。
    包括:
  • 磁盘读的次数
  • 磁盘读的毫秒数
  • 磁盘写的次数
  • 磁盘写的毫秒数
  • 正在处理的输入/输出请求数
  • 花费在I/O操作上的毫秒数
  • 读扇区的次数(一个扇区等于512B)
  • 写扇区的次数(一个扇区等于512B)
 
注意:本环境要监控的服务器在阿里云上,所以每台服务器上的设备名称不同,为解决此问题,我定义了多个模板来解决此问题!
各位小伙伴请根据实际情况进行配置
 
二、步骤概览
 
1.数据来源:/proc/diskstats
/proc/diskstats文件说明
$1: 主设备号
$2: 次设备号
$3: 设备名称
$4: 读完成次数
$6: 读扇区的次数(一个扇区等于512B)
$7: 读磁盘的毫秒数
$8: 写完成次数
$10: 写扇区的次数(一个扇区等于512B)
$11: 磁盘写的毫秒数
$12: 正在处理的输入/输出请求数
$13: 花费在I/O操作上的毫秒数
2.自定义item
3.在zabbix_server端测试
4.配置Zabbix-server WEB UI
5.监测最新数据
 
二、操作步骤:
    
1.自定义item并重新加载Agent.
~]# vim /etc/zabbix/zabbix_agentd.d/userparameter_disk_io.conf
#磁盘读的次数
UserParameter=custom.vfs.dev.read.ops[*],cat /proc/diskstats | grep $1 | head -1 | awk '{print $$4}'
#磁盘读的毫秒数
UserParameter=custom.vfs.dev.read.ms[*],cat /proc/diskstats | grep $1 | head -1 | awk '{print $$7}'
#磁盘写的次数
UserParameter=custom.vfs.dev.write.ops[*],cat /proc/diskstats | grep $1 | head -1 | awk '{print $$8}'
#磁盘写的毫秒数
UserParameter=custom.vfs.dev.write.ms[*],cat /proc/diskstats | grep $1 | head -1 | awk '{print $$11}'
#正在处理的输入/输出请求数
UserParameter=custom.vfs.dev.io.active[*],cat /proc/diskstats | grep $1 | head -1 | awk '{print $$12}'
#花费在IO操作上的毫秒数
UserParameter=custom.vfs.dev.io.ms[*],cat /proc/diskstats | grep $1 | head -1 | awk '{print $$13}'
#读扇区的次数(一个扇区的等于512B)
UserParameter=custom.vfs.dev.read.sectors[*],cat /proc/diskstats | grep $1 | head -1 | awk '{print $$6}'
#写扇区的次数(一个扇区的等于512B)
UserParameter=custom.vfs.dev.write.sectors[*],cat /proc/diskstats | grep $1 | head -1 | awk '{print $$10}
~]# systemctl restart zabbix-agent
2.在zabbix-server端测试
 
~]# zabbix_get -s 192.168.1.100 -k custom.vfs.dev.io.ms[xvda1]       // 如果没有这个命令的话则需要使用yum安装(yum -y install zabbix-get)
2547825
~]# zabbix_get -s 192.168.1.100 -k custom.vfs.dev.read.sectors[xvda1]
7716602
....等等,当全部数据都可获取时,则说明item生效.
3.配置Zabbix-server WEB UI
 
(1)如图操作:配置 → 模板 → 创建模板.
 
(2)如图操作:自定义模板名称 → 将被监控主机群组加入到"群组"中.
 
(3)如图操作:监控项 → 创建监控项
 
(4)如图操作:自定义名称 → 采集数据的方式 → 手动指定键值 → 指定单位 → 指定应用集 → 进程 → 每秒更改 → 点击更新.
 
 
(5)如图操作:再次新建监控项 → 名称 → 获取数据方式 → 自定义key → 数值类型 → 数据单位 → 进程 → 自定义倍数(512) → 每秒更改 → 更新.
 
 
(6)如图所示:下面的操作都与上述描述差的不多,在此不做注释.
 
 
(7) 如图操作:
 
(8)如图操作:
 
(9) 如图操作:
 
4.监测最新数据,如图所示(如果有多块磁盘,那么就配置多个模板,模板间可互相克隆后修改$1位置的磁盘名称)
01-09 21:47