ZABBIX监控磁盘性能指标

本文介绍了如何使用Zabbix监控服务器磁盘性能,通过理解/proc/diskstats获取磁盘指标,编写自定义监控脚本,配置Zabbix Agent及自动发现规则,实现磁盘IO读写速率的动态监控。详细步骤包括修改配置文件、创建模板和监控项原型等。

zabbix一直是小规模互联网公司服务器性能监控首选,首先是免费,其次,有专门的公司和社区开发维护,使其稳定性和功能都在不断地增强和完善。zabbix拥有详细的UI界面和分组策略,在被监控的服务器上安装好agent后,无需添加任何监控选项,因为zabbix自带一些必要的监控,如agent.ping之类,zabbix支持画图,这个是专门给boss们看的,极其重要。另外还支持用户自定义监控选项,这一点非常方便,今天我要说的就是磁盘监控,标题中为动态的监控,意指智能的识别磁盘个数,并生成相应的监控选项,因为每台服务器的磁盘可能不一样,所以我是使用zabbix的discovery方式。

本文zabbix模板与图片下载链接模板下载

1、磁盘性能指标获取

首先理解磁盘性能指标IO等问题,需要理解diskstats这个文件:
首先来看下diskstats里面都有些什么,下面截取的是一个diskstats文件内容:

cat /proc/diskstats

  8       0 sda 8567 1560 140762 3460 0 0 0 0 0 2090 3440
   8       1 sda1 8565 1557 140722 3210 0 0 0 0 0 1840 3190
   8      16 sdb 8157 1970 140762 2940 0 0 0 0 0 1710 2890
   8      17 sdb1 8155 1967 140722 2900 0 0 0 0 0 1670 2850
   8      32 sdc 8920 1574 206410 7870 430 0 461 250 0 6820 8120
   8      33 sdc1 8918 1571 206370 7840 430 0 461 250 0 6790 8090
   8      48 sdd 209703 1628 341966 1318450
### Zabbix 监控 MySQL 性能指标列表及配置方法 Zabbix 是一种功能强大的开源监控解决方案,能够通过内置模板或自定义脚本实现对 MySQL 数据库的性能监控。以下是 MySQL 性能指标列表及其配置方法。 #### 1. 常见的 MySQL 性能指标 以下是一些常用的 MySQL 性能指标,可以通过 Zabbix 进行监控: - **查询相关指标**: - `Queries`:每秒执行的查询总数[^1]。 - `Com_select`:每秒执行的 SELECT 查询数[^1]。 - `Com_insert`:每秒执行的 INSERT 操作数。 - `Com_update`:每秒执行的 UPDATE 操作数。 - `Com_delete`:每秒执行的 DELETE 操作数[^1]。 - **事务相关指标**: - `Com_commit`:每秒提交的事务数[^1]。 - `Com_rollback`:每秒回滚的事务数[^4]。 - **缓存命中率**: - `Qcache_hits`:查询缓存命中的次数。 - `Qcache_inserts`:插入到查询缓存中的查询数。 - `Qcache_lowmem_prunes`:由于内存不足而从缓存中删除的查询数。 - **连接相关指标**: - `Connections`:尝试连接 MySQL 服务器的次数。 - `Threads_connected`:当前打开的连接数。 - `Max_used_connections`:曾经同时打开的最大连接数[^1]。 - **其他关键指标**: - `Innodb_buffer_pool_reads`:从磁盘读取缓冲池的次数。 - `Innodb_buffer_pool_read_requests`:缓冲池满足的读取请求次数。 - `Innodb_rows_inserted`、`Innodb_rows_updated`、`Innodb_rows_deleted`、`Innodb_rows_read`:InnoDB 存储引擎的行操作统计[^1]。 #### 2. 配置方法 以下是通过 Zabbix 监控 MySQL 性能指标的具体配置步骤: - **使用官方模板**: Zabbix 官方提供了名为“MySQL by Zabbix agent”的模板[^2],可以直接导入到 Zabbix 中,无需额外的外部脚本。该模板支持多种 MySQL 性能指标的采集,例如查询、事务和缓存命中率等。 - **手动配置 UserParameter**: 如果需要自定义监控指标,可以通过修改 zabbix_agentd.conf 文件添加 UserParameter。例如: ```bash UserParameter=mysql.Com_rollback,mysqladmin -uroot extended-status | grep -w "Com_rollback" | cut -d"|" -f3 ``` 上述命令用于采集 `Com_rollback` 指标[^4]。 - **配置项说明**: - 确保 zabbix_agentd 已正确安装在被监控的 MySQL 服务器上,并且具有访问数据库的权限[^3]。 - 在 Zabbix Web 界面中创建主机并关联“MySQL by Zabbix agent”模板[^2]。 - 配置触发器以检测异常情况,例如高连接数或低缓存命中率。 #### 3. 示例代码 以下是一个示例 zabbix_agentd.conf 配置片段,用于采集自定义 MySQL 性能指标: ```bash UserParameter=mysql.Queries,mysqladmin -uroot extended-status | grep -w "Queries" | cut -d"|" -f3 UserParameter=mysql.Com_select,mysqladmin -uroot extended-status | grep -w "Com_select" | cut -d"|" -f3 UserParameter=mysql.Com_insert,mysqladmin -uroot extended-status | grep -w "Com_insert" | cut -d"|" -f3 ``` #### 4. 注意事项 - 确保 zabbix_agentd 用户具有足够的权限运行 `mysqladmin` 命令。 - 根据实际需求调整监控频率,避免对 MySQL 性能造成额外负担。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酱江奖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值