MySQL进行监控配置的详细指南

 更新时间:2025年06月23日 08:53:50   作者:慧一居士  
这篇文章主要和大家分享一个完整的 MySQL 监控配置实战方案,涵盖监控工具安装,核心指标采集,可视化展示,告警配置等内容,需要的可以了解下

以下是一个完整的 MySQL 监控配置实战方案,涵盖监控工具安装、核心指标采集、可视化展示、告警配置等内容。基于 Prometheus + Grafana + mysqld_exporter 实现。

一、环境准备

1.操作系统:CentOS 7+ / Ubuntu 20+

2.MySQL 版本:5.7+ 或 8.0+

3.监控工具栈:

  • Prometheus(数据采集与告警)
  • Grafana(可视化)
  • mysqld_exporter(MySQL 数据导出)

二、部署监控组件

1. 安装 Prometheus & Grafana

# 下载并解压
wget https://github.com/prometheus/prometheus/releases/download/v2.45.0/prometheus-2.45.0.linux-amd64.tar.gz
wget https://dl.grafana.com/oss/release/grafana-10.0.0.linux-amd64.tar.gz

# 解压
tar -zxvf prometheus-*.tar.gz
tar -zxvf grafana-*.tar.gz

# 移动到 /usr/local
mv prometheus-* /usr/local/prometheus
mv grafana-* /usr/local/grafana

# 创建符号链接
ln -s /usr/local/prometheus/bin/prometheus /usr/local/bin/prometheus
ln -s /usr/local/grafana/bin/grafana-server /usr/local/bin/grafana-server

2. 配置 Prometheus

编辑 /usr/local/prometheus/prometheus.yml,添加以下内容:

global:
  scrape_interval: 15s # 采集频率

scrape_configs:
  - job_name: 'mysql'
    static_configs:
      - targets: ['localhost:9104'] # mysqld_exporter 默认端口

3. 安装 mysqld_exporter

# 下载并解压
wget https://github.com/prometheus/mysqld_exporter/releases/download/v0.14.0/mysqld_exporter-0.14.0.linux-amd64.tar.gz
tar -zxvf mysqld_exporter-*.tar.gz
cd mysqld_exporter-*

# 移动到系统路径
mv mysqld_exporter /usr/local/bin/

# 创建配置文件目录
mkdir -p /etc/mysqld_exporter

4. 配置 mysqld_exporter

创建 /etc/mysqld_exporter/.my.cnf,配置 MySQL 访问权限:

[client]
user=monitor_user    # 用于监控的 MySQL 用户
password=your_password
host=127.0.0.1
port=3306

创建监控用户(替换为实际密码):

CREATE USER 'monitor_user'@'localhost' IDENTIFIED BY 'your_password';
GRANT PROCESS, REPLICATION CLIENT, SHOW DATABASES ON *.* TO 'monitor_user'@'localhost';
FLUSH PRIVILEGES;

启动 mysqld_exporter:

mysqld_exporter --config.my-cnf=/etc/mysqld_exporter/.my.cnf &

三、配置 Prometheus 抓取 MySQL 指标

在 prometheus.yml 中添加:

scrape_configs:
  - job_name: 'mysql'
    metrics_path: /metrics
    static_configs:
      - targets: ['localhost:9104']

重启 Prometheus:

systemctl restart prometheus

四、部署 Grafana 并配置仪表盘

1.启动 Grafana:

grafana-server web &

访问 http://<服务器IP>:3000,默认账号 admin/admin。

2.添加 Prometheus 数据源:

  • 进入 Configuration -> Data Sources -> Add data source
  • 选择 Prometheus,填写 URL http://localhost:9090,保存。

3.导入 MySQL 监控仪表盘:

访问 Grafana Dashboard 库,搜索 MySQL。

推荐导入:

五、核心监控指标

通过 Grafana 展示以下关键指标:

1.基础状态:

  • Uptime
  • Version
  • Connections (Threads_connected)

2.性能指标:

  • QPS (Queries per second)
  • TPS (Transactions per second)
  • InnoDB Buffer Pool Usage
  • Slow Queries

3.资源使用:

  • CPU Usage (User/System Time)
  • Memory Usage (Key buffer, InnoDB buffer pool)
  • Disk I/O (Read/Write throughput)

4.高可用性:

  • Replication Status (Seconds_Behind_Master)
  • MGR Member State

六、告警配置

在 Prometheus 中配置告警规则(/etc/prometheus/alert.rules):

groups:
  - name: mysql_alerts
    rules:
      - alert: HighConnections
        expr: mysql_global_status_threads_connected > 100
        for: 5m
        labels:
          severity: warning
        annotations:
          summary: "MySQL 活跃连接数过高"
      - alert: ReplicationDelay
        expr: mysql_slave_seconds_behind_master > 300
        for: 5m
        labels:
          severity: critical
        annotations:
          summary: "MySQL 主从复制延迟超过 5 分钟"

在 Prometheus 中加载规则文件,并配置 Alertmanager 通知(邮件/钉钉/微信)。

七、自动化脚本增强

编写脚本定期检查慢查询、表碎片、索引效率等:

#!/bin/bash
# slow_query_report.sh

# 获取慢查询日志
slow_log=$(grep "^# Query" /var/log/mysql/slow.log | tail -n 10)
echo "慢查询日志:" >> /tmp/mysql_report.txt
echo "$slow_log" >> /tmp/mysql_report.txt

# 检查表碎片
table_fragmentation=$(mysql -e "SELECT table_schema, table_name, round((data_length - index_length) / data_length * 100, 2) as fragmentation FROM information_schema.tables WHERE fragmentation > 10;")
echo "表碎片情况:" >> /tmp/mysql_report.txt
echo "$table_fragmentation" >> /tmp/mysql_report.txt

# 发送邮件
mail -s "MySQL Daily Report" admin@example.com < /tmp/mysql_report.txt

设置定时任务:

crontab -e
# 每天凌晨 1 点执行
0 1 * * * /path/to/slow_query_report.sh

八、验证与优化

1.模拟故障测试:

  • 停止 MySQL 服务,验证 Prometheus 是否触发告警。
  • 插入大量慢查询,检查慢查询统计是否正常。

2.调整阈值:

根据业务流量调整 QPS、TPS、连接数告警阈值。

3.长期存储:

配置 Prometheus 长期存储(如 VictoriaMetrics 或 Thanos)。

总结

通过以上配置,可以实现对 MySQL 的全方位监控,包括实时性能、资源使用、高可用性状态等。结合告警和自动化脚本,可提前发现潜在问题,保障数据库稳定性。

到此这篇关于MySQL进行监控配置的详细指南的文章就介绍到这了,更多相关MySQL监控配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • KubeSphere部署mysql的详细步骤

    KubeSphere部署mysql的详细步骤

    本文介绍了在KubeSphere中部署Mysql的详细步骤,包括创建mysql配置、pvc挂载、工作负载、服务,并测试数据库连接,步骤详尽,包括yaml配置和环境变量设置,特别强调了路径一致性和外部访问设置,还提到了使用NodePort模式解决自定义域名连接问题
    2024-10-10
  • MySQL数据库高可用HA实现小结

    MySQL数据库高可用HA实现小结

    MySQL数据库是目前开源应用最大的关系型数据库,有海量的应用将数据存储在MySQL数据库中,这篇文章主要介绍了MySQL数据库高可用HA实现,需要的朋友可以参考下
    2022-01-01
  • mysql grants小记

    mysql grants小记

    grant命令是对mysql数据库进行用户创建,权限或其他参数控制的强大的命令,官网上介绍它就有几大页,要用精它恐怕不是一日半早的事情,权宜根据心得慢慢领会吧!
    2011-05-05
  • 常见php与mysql中文乱码问题解决办法

    常见php与mysql中文乱码问题解决办法

    MySQL对中文的支持程度还是很有限的,尤其是新手,但凡出现乱码问题,就会头大。
    2014-09-09
  • MySQL execute、executeUpdate、executeQuery三者的区别

    MySQL execute、executeUpdate、executeQuery三者的区别

    这篇文章主要介绍了MySQL execute、executeUpdate、executeQuery三者的区别的相关资料,需要的朋友可以参考下
    2017-05-05
  • MySQL 5.7并发复制隐式bug实例分析

    MySQL 5.7并发复制隐式bug实例分析

    这篇文章主要给大家介绍了关于MySQL 5.7并发复制隐式bug的相关资料,文中介绍的非常详细,对大家学习或者使用mysql5.7具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • Centos7下安装和配置MySQL5.7.20的详细教程

    Centos7下安装和配置MySQL5.7.20的详细教程

    这篇文章主要介绍了Linux(CentOS7)下安装和配置MySQL5.7.20详细教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价,需要的朋友可以参考下
    2020-05-05
  • linux下启动或者关闭MySQL数据库的多种方式

    linux下启动或者关闭MySQL数据库的多种方式

    ,在Linux服务器上管理MySQL服务是一个基本的运维任务,下面这篇文章主要给大家介绍了关于linux下启动或者关闭MySQL数据库的多种方式,文中通过代码以及图文介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • Mysql注入中的outfile、dumpfile、load_file函数详解

    Mysql注入中的outfile、dumpfile、load_file函数详解

    这篇文章主要介绍了Mysql注入中的outfile、dumpfile、load_file,需要的朋友可以参考下
    2018-05-05
  • MySql 修改密码后的错误快速解决方法

    MySql 修改密码后的错误快速解决方法

    今天在MySql5.6操作时报错:You must SET PASSWORD before executing this statement解决方法,需要的朋友可以参考下
    2016-11-11

最新评论