Zabbix实战企业监控之MySQL监控

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

1 前言

Zabbix对于MySQL的监控官方教程好像还没有给出明确的配置方法,以下是我参阅一些资料整理出来的配置方法,现与各位博友分享。

2 理论部分

2.1 Key值的获取原理

2.1.1 Zabbix Server部分的Key定义

查看模板的Items


wKioL1diGs6CZsUIAAESwF6-jv8018.png

模板定义的Items如下:

wKiom1diGdnTSxQKAAJCU__jlZU886.png

以Items“MySQL uptime”为例Key的内容如下:

wKioL1diHgfgCbsgAAFCW-AwmPI650.png

可见,关键部分是Key值mysql.status[Uptime]相当于变量名称

2.1.2 Zabbix Agens部分的Key传参定义

1)传参数的定义文件

1
less  /etc/zabbix/zabbix_agentd .d /userparameter_mysql .conf

2)传参的定义格式

可发现如下行:

1
UserParameter=mysql.status[*], echo  "show global status where Variable_name='$1';"  | HOME= /var/lib/zabbix  mysql -N |  awk  '{print $$2}'

定义以逗号分隔,可简化如下:

1
用户自定义参数名称,用户自定义参数取值(shell命令)

注意:

用户自定义参数名称:“*”代表Zabbix Server可传入任何具体的变量参数

用户自定义参数取值:“$1”代表Zabbix Server可传入的变量参数

3)如传入参数为“Uptime”则变为

1
UserParameter=mysql.status[Uptime], echo  "show global status where Variable_name='Uptime';"  | HOME= /var/lib/zabbix  mysql -N |  awk  '{print $$2}'

4)用户自定义参数取值部分Shell指定可取得具体的数值(需先数据库授权和连接数据库授权配置)

wKioL1diI4zh0eO1AAAV9pnUAKc185.png

所以指定结果是:

1
UserParameter=mysql.status[Uptime],165538

就这样,MySQL的值被送到Zabbix Server

3 实践部分

3.1 环境描述

Zabbix Server:

ipaddress=10.168.0.160

hostname=zabbix


Zabbix Agens:

ipaddress=10.168.0.99

hostname=mysqlSer

app=mysqld


Zabbix Server&Agens端的配置请参阅:

http://cmdschool.blog.51cto.com/2420395/1723530

3.2 使用户自定义参数生效

In Zabbix Agens:

vim编辑/etc/zabbix/zabbix_agentd.conf开启以下两个参数

1
2
Include= /etc/zabbix/zabbix_agentd .d/
UnsafeUserParameters=0

注:完成以上配置“userparameter_mysql.conf”里面的定义才生效

3.3 授予Zabbix Agens数据访问权限

In Zabbix Server:

MySQL权限配置

1
2
3
4
mysql -uroot -p
GRANT SELECT ON mysql.* TO  'zabbix' @ 'localhost'  IDENTIFIED BY  'zabbix' ;
flush privileges;
show grants  for  zabbix@localhost;

3.4 配置Zabbix Agens数据库访问权限

In Zabbix Agens:

3.4.1 确定数据库连接文件的目录

用如下命令查看"HOME"目录所定义路径

1
cat  /etc/zabbix/zabbix_agentd .d /userparameter_mysql .conf |  egrep  - v  "(^#|^$)"  grep  HOME

显示如下:

1
2
3
UserParameter=mysql.status[*], echo  "show global status where Variable_name='$1';"  | HOME= /var/lib/zabbix  mysql -N |  awk  '{print $$2}'
UserParameter=mysql.size[*], echo  "select sum($(case " $3 " in both|" ") echo " data_length+index_length ";; data|index) echo " $3_length ";; free) echo " data_free ";; esac)) from information_schema.tables$([[ " $1 " = " all " || ! " $1 " ]] || echo "  where table_schema= '$1' ")$([[ " $2 " = " all " || ! " $2 " ]] || echo " and table_name= '$2' ");"  | HOME= /var/lib/zabbix  mysql -N
UserParameter=mysql. ping ,HOME= /var/lib/zabbix  mysqladmin  ping  grep  -c alive

注:以上表明数据库连接文件应当配置在“/var/lib/zabbix”

3.4.2 确定MySQL的PID文件路径

用如下命令查看MySQL的PID文件的路径

1
grep  pid- file  /etc/my .cnf

显示如下:

1
pid- file = /var/run/mysqld/mysqld .pid

3.4.3 配置数据库连接文件

根据前面获取到的路径创建数据库连接文件

 vim编辑/var/lib/zabbix/.my.cnf输入如下内容:

1
2
3
4
5
6
7
8
9
10
[mysql]
host     = localhost
user     = zabbix
password = zabbix
socket   =  /var/lib/mysql/mysql .sock
[mysqladmin]
host     = localhost
user     = zabbix
password = zabbix
socket   =  /var/lib/mysql/mysql .sock

3.5 重启并使配置生效

In Zabbix Agens:

重启Agent服务

1
/etc/init .d /zabbix-agent  restart

3.6 命令行确认自定义KEY

In Zabbix Agens:

1
  echo  "show global status where Variable_name='Uptime';"  | HOME= /var/lib/zabbix  mysql -N |  awk  '{print $2}'

In Zabbix Server:

1
2
zabbix_get -s 10.168.0.99 -k mysql.status[Uptime]
zabbix_get -s 10.168.0.99 -k mysql.version

3.7 添加主机的监控模板

In Zabbix的web控制台

Configuration->Hosts->单击“主机名称”->Templates->Select->Template App MySQL->Add->Update

3.8 确认监控结果

Monitoring->Graphs

Host选择具体的“主机名称”

Graph选择“MySQL bandwidth”或“MySQL operations”查看监控的图像

wKiom1diL8DRrJDBAAHF92B_BPE225.png










本文转自 tanzhenchao 51CTO博客,原文链接:http://blog.51cto.com/cmdschool/1786611,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
12天前
|
SQL 存储 关系型数据库
不允许你不知道的 MySQL 优化实战(三)
不允许你不知道的 MySQL 优化实战(三)
30 1
|
12天前
|
SQL 关系型数据库 MySQL
不允许你不知道的 MySQL 优化实战(二)
不允许你不知道的 MySQL 优化实战(二)
27 2
|
12天前
|
Prometheus 监控 Cloud Native
使用mysqld_exporter监控所有MySQL实例
使用mysqld_exporter监控所有MySQL实例
44 2
|
4天前
|
监控 关系型数据库 MySQL
实时计算 Flink版产品使用合集之监控 MySQL 数据写入到 StarRocks 中,在初始化成功后,但无法监控到插入的数据是什么导致的
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
4天前
|
SQL 关系型数据库 数据库
阿里云数据库 RDS SQL Server版实战【性能优化实践、优点探析】
本文探讨了Amazon RDS SQL Server版在云数据库中的优势,包括高可用性、可扩展性、管理便捷、安全性和成本效益。通过多可用区部署和自动备份,RDS确保数据安全和持久性,并支持自动扩展以适应流量波动。可视化管理界面简化了监控和操作,而数据加密和访问控制等功能保障了安全性。此外,弹性计费模式降低了运维成本。实战应用显示,RDS SQL Server版能有效助力企业在促销高峰期稳定系统并保障数据安全。阿里云的RDS SQL Server版还提供了弹性伸缩、自动备份恢复、安全性和高可用性功能,进一步优化性能和成本控制,并与AWS生态系统无缝集成,支持多种开发语言和框架。
28 2
|
12天前
|
缓存 关系型数据库 MySQL
MySQL数据库性能优化实战
【4月更文挑战第30天】本文探讨了MySQL性能优化实战技巧,包括硬件与配置优化(如使用SSD、增加内存和调整配置参数)、索引优化(创建合适索引、使用复合索引及定期维护)、查询优化(避免全表扫描、减少JOIN和使用LIMIT)、分区与分片(表分区和数据库分片),以及使用缓存、定期清理数据库和监控诊断。通过这些方法,可以提升数据库性能和响应速度。
|
12天前
|
存储 关系型数据库 MySQL
MySQL数据库实战:从入门到精通
本文介绍了MySQL的使用和优化,适合Web开发者阅读。首先,确保安装并配置好MySQL,熟悉SQL基础。接着,通过命令行客户端连接数据库,执行创建、查询、添加、修改和删除数据等操作。学习数据类型并创建表存储数据。最后,探讨了数据库优化,包括查询优化和索引使用,以提升性能。
38 2
|
12天前
|
安全 关系型数据库 MySQL
node实战——后端koa结合jwt连接mysql实现权限登录(node后端就业储备知识)
node实战——后端koa结合jwt连接mysql实现权限登录(node后端就业储备知识)
28 3
|
12天前
|
SQL 关系型数据库 MySQL
不允许你不知道的 MySQL 优化实战(一)
不允许你不知道的 MySQL 优化实战(一)
28 2
|
10天前
|
关系型数据库 MySQL API
实时计算 Flink版产品使用合集之可以通过mysql-cdc动态监听MySQL数据库的数据变动吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。

推荐镜像

更多