默认的 Zabbix 监控模板中,对于磁盘主要是剩余空间之类的监控,对于 IO 方面却没有,好在 Zabbix 提供了丰富的定制功能,可自行添加想要监控的任意内容。具体步骤如下:

1、在被监控服务器的配置文件(/etc/zabbix/zabbix_agentd.conf)中添加以下内容:

1 UserParameter=custom.vfs.dev.read.ops[*],cat /proc/diskstats ¦ grep $1 ¦ head -1 ¦ awk '{print $$4}'
2 UserParameter=custom.vfs.dev.read.ms[*],cat /proc/diskstats ¦ grep $1 ¦ head -1 ¦ awk '{print $$7}'
3 UserParameter=custom.vfs.dev.write.ops[*],cat /proc/diskstats ¦ grep $1 ¦ head -1 ¦ awk '{print $$8}'
4 UserParameter=[*],cat /proc/diskstats ¦ grep $1 ¦ head -1 ¦ awk '{print $$11}'
5 UserParameter=custom.vfs.dev.io.active[*],cat /proc/diskstats ¦ grep $1 ¦ head -1 ¦ awk '{print $$12}'
6 UserParameter=custom.vfs.dev.io.ms[*],cat /proc/diskstats ¦ grep $1 ¦ head -1 ¦ awk '{print $$13}'
7 UserParameter=custom.vfs.dev.read.sectors[*],cat /proc/diskstats ¦ grep $1 ¦ head -1 ¦ awk '{print $$6}'
8 UserParameter=custom.vfs.dev.write.sectors[*],cat /proc/diskstats ¦ grep $1 ¦ head -1 ¦ awk '{print $$10}'

可以先测试看其是否生效,使用如下命令,看是否正常返回数字。注意在命令行运行时,grep 那里的 $1 需根据自己磁盘设定修改为 sda 或 sdb,awk 那里需去除一个 $ 符号。

1 cat /proc/diskstats ¦ grep sda ¦ head -1 ¦ awk '{print $4}'

2、被监控主机重启 agent

1 /etc/init.d/zabbix_agentd_ctl restart

3、在 zabbix server 上测试能否接收数据,将其中的 AgentServerIP 修改为被监控服务器的IP,注意这里是在运行 zabbix 服务端的机器上执行此操作。如果返回的是一串数字则正确,如果返回 ZBX_NOTSUPPORTED ,请检查确认被监控主机的 agent 是否有重启,网络端口是否开放。

1 zabbix_get -s AgentServerIP -p 10050 -k custom.vfs.dev.write.ops[sda]

4、在 zabbix web 配置界面的模板中,导入这里提供的模板。并将此模板关联到要监控的服务器主机上,很快就可以在 Latest data 中看到获取的数据并可画出趋势图了。

参考链接:
Getting hard disk performance stats from zabbix
/proc/diskstats各域说明
http://www.nowo.com/disk-performance-monitoring-in-zabbix