@Prometheus 监控-MySQL (Mysqld Exporter)
文章目录
- **Prometheus 监控 MySQL **
- **1. 目标**
- **2. 环境准备**
- **2.1 所需组件**
- **2.2 权限要求**
- **3. 部署 mysqld_exporter**
- **3.1 下载与安装**
- **3.2 创建配置文件**
- **3.3 创建 Systemd 服务**
- **3.4 验证 Exporter**
- **4. 配置 Prometheus**
- **4.1 添加 Job 到 `prometheus.yml`**
- **4.2 重载 Prometheus**
- **5. 核心监控指标说明**
- **6. 告警规则配置**
- **6.1 创建告警规则文件**
- **6.2 在 `prometheus.yml` 中加载规则**
- **7. Grafana 仪表盘配置**
- **8. 维护与优化**
- **8.1 定期检查**
- **8.2 安全加固**
- **8.3 性能调整**
- **9. 故障排查**
- **9.1 Exporter 无数据**
- **9.2 Prometheus 未抓取**
- **10. 附录**
**Prometheus 监控 MySQL **
1. 目标
- 实时监控 MySQL 关键性能指标(如连接数、查询吞吐量、复制状态等)。
- 设置告警规则,及时发现数据库异常。
- 通过 Grafana 可视化监控数据。
2. 环境准备
2.1 所需组件
组件 | 作用 | 安装位置 |
---|---|---|
Prometheus Server | 指标采集与存储 | 监控服务器 |
mysqld_exporter | 暴露 MySQL 指标 | MySQL 服务器 |
Grafana | 数据可视化 | 监控服务器 |
Alertmanager | 告警通知管理 | 监控服务器 |
2.2 权限要求
- MySQL 用户需具备
PROCESS
,REPLICATION CLIENT
,SELECT
权限:CREATE USER 'exporter'@'localhost' IDENTIFIED BY 'YourStrongPassword'; GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO 'exporter'@'localhost'; FLUSH PRIVILEGES;
3. 部署 mysqld_exporter
3.1 下载与安装
# 下载最新版 (替换版本号)
VERSION="0.15.1"
wget https://github.com/prometheus/mysqld_exporter/releases/download/v${VERSION}/mysqld_exporter-${VERSION}.linux-amd64.tar.gz
tar xvf mysqld_exporter-${VERSION}.linux-amd64.tar.gz
sudo mv mysqld_exporter-${VERSION}.linux-amd64/mysqld_exporter /usr/local/bin/
3.2 创建配置文件
创建 .my.cnf
文件存储数据库连接信息:
sudo tee /etc/.mysqld_exporter.cnf <<EOF
[client]
user=exporter
password=YourStrongPassword
host=localhost
port=3306
EOF
sudo chmod 600 /etc/.mysqld_exporter.cnf # 限制权限
3.3 创建 Systemd 服务
/etc/systemd/system/mysqld_exporter.service
:
[Unit]
Description=MySQL Prometheus Exporter
After=network.target[Service]
User=mysqld_exporter
ExecStart=/usr/local/bin/mysqld_exporter \--config.my-cnf=/etc/.mysqld_exporter.cnf \--collect.global_status \--collect.info_schema.innodb_metrics \--collect.slave_status \--collect.info_schema.processlistRestart=always[Install]
WantedBy=multi-user.target
sudo systemctl daemon-reload
sudo systemctl start mysqld_exporter
sudo systemctl enable mysqld_exporter
3.4 验证 Exporter
访问指标接口:
curl http://localhost:9104/metrics
应输出包含 mysql_
前缀的指标。
4. 配置 Prometheus
4.1 添加 Job 到 prometheus.yml
scrape_configs:- job_name: 'mysql'static_configs:- targets: ['mysql-server-ip:9104'] # Exporter 地址relabel_configs:- source_labels: [__address__]target_label: instancereplacement: 'mysql-primary' # 实例标识
4.2 重载 Prometheus
curl -X POST http://localhost:9090/-/reload # 或重启服务
5. 核心监控指标说明
指标名称 | 含义 | 告警建议 |
---|---|---|
mysql_global_status_threads_connected | 当前连接数 | > 80% max_connections |
mysql_global_status_threads_running | 活跃连接数 | 持续 > 100 |
mysql_global_status_slow_queries | 慢查询计数 | 短时间内突增 |
mysql_global_variables_max_connections | 最大连接数 | 规划容量参考 |
mysql_slave_status_slave_io_running | 主从 IO 线程状态 | ≠ 1 (异常) |
mysql_info_schema_innodb_row_lock_time_avg | 平均行锁等待时间 | > 500ms |
6. 告警规则配置
6.1 创建告警规则文件
/etc/prometheus/rules/mysql_alerts.yml
:
groups:
- name: MySQL-Alertsrules:- alert: MySQLHighConnectionsexpr: mysql_global_status_threads_connected / mysql_global_variables_max_connections * 100 > 80for: 5mlabels:severity: warningannotations:summary: "MySQL 高连接数 ({{ $value }}%)"description: "实例 {{ $labels.instance }} 连接数超过 80% 限制"- alert: MySQLReplicationFailureexpr: mysql_slave_status_slave_io_running != 1 or mysql_slave_status_slave_sql_running != 1for: 1mlabels:severity: criticalannotations:summary: "MySQL 复制中断 ({{ $labels.instance }})"
6.2 在 prometheus.yml
中加载规则
rule_files:- "/etc/prometheus/rules/mysql_alerts.yml"
7. Grafana 仪表盘配置
- 导入官方 Dashboard:
- ID
7362
(MySQL Overview)
- ID
- 配置 Prometheus 为数据源。
8. 维护与优化
8.1 定期检查
- 验证 Exporter 状态:
systemctl status mysqld_exporter
- 检查指标收集延迟:
prometheus_target_interval_length_seconds
- 审核 MySQL 用户权限(每年至少一次)。
8.2 安全加固
- 使用 TLS 加密 Exporter 通信:
mysqld_exporter --web.config.file=/path/to/web-config.yml
web-config.yml
示例:tls_server_config:cert_file: server.crtkey_file: server.key
8.3 性能调整
- 限制采集的指标(减少负载):
--no-collect.info_schema.tables # 禁用表统计
- 调整 Prometheus 抓取间隔(默认 15s):
scrape_interval: 30s # prometheus.yml
9. 故障排查
9.1 Exporter 无数据
- 检查 MySQL 用户权限。
- 测试连接:
mysql --defaults-file=/etc/.mysqld_exporter.cnf -e "SHOW STATUS"
- 查看 Exporter 日志:
journalctl -u mysqld_exporter -f
9.2 Prometheus 未抓取
- 访问
http://prom-server:9090/targets
检查 Target 状态。 - 验证网络连通性:
telnet mysql-server-ip 9104
10. 附录
- mysqld_exporter 官方文档:
https://github.com/prometheus/mysqld_exporter - MySQL 监控关键指标指南:
https://prometheus.io/docs/guides/mysqld-exporter/
按照此文档,可实现 MySQL 的全面监控与告警,确保数据库稳定性。部署后需通过压力测试验证监控有效性,并根据业务特点调整告警阈值。
相关文章:
@Prometheus 监控-MySQL (Mysqld Exporter)
文章目录 **Prometheus 监控 MySQL ****1. 目标****2. 环境准备****2.1 所需组件****2.2 权限要求** **3. 部署 mysqld_exporter****3.1 下载与安装****3.2 创建配置文件****3.3 创建 Systemd 服务****3.4 验证 Exporter** **4. 配置 Prometheus****4.1 添加 Job 到 prometheus…...

pc端小卡片功能-原生JavaScript金融信息与节日日历
代码如下 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>金融信息与节日日历</title><…...
窗口聚合窗口聚合
taskmanager.memory.managed.fraction 在 Apache Flink 中,配置项 taskmanager.memory.managed.fraction 用于控制任务管理器(TaskManager)所占用的总内存中,分配给管理内存(Managed Memory)的比例。管理内…...
es在Linux安装
如果服务器能访问外网: wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.4.0.zip不能就手动下载,解压文件到合适目录 unzip elasticsearch-6.4.0.zip -d /opt/ mv /opt/elasticsearch-6.4.0 /opt/elasticsearch创建和日志…...

Go语言学习-->第一个go程序--hello world!
Go语言学习–>第一个go程序–hello world! 1 写代码前的准备 1 创建编写代码的文件夹 2 使用vscode打开3 项目初始化 **go mod init*(初始化一个go mod)Go Module 是 Go 1.11 版本引入的官方依赖管理系统,用于替代传统的 GOPATH…...

高雄市12岁以下身心障碍儿童口腔保健合作院所名单数据集
描述: 关键字:儿童、口腔、保健、院所、名单 字段特征:序号、院所分级、合作医疗院所、市话、地址 语言:繁体 行数/数量:129行,5列 数据量 :7.27KB 格式:CSV、JSON、XML 目录…...
Spring Boot 自动参数校验
在 Spring Boot 中实现参数自动校验主要依靠 Java Bean Validation API(JSR 380)和 Spring 的集成支持。以下是详细实现步骤: 1. 添加依赖 在 pom.xml 中添加验证依赖: <dependency><groupId>org.springframework.b…...

破局新能源消纳难题!安科瑞智慧能源平台助力10KV配电网重构未来
一、政策驱动:新型配电网迎来 “智慧化” 刚需 随着分布式光伏、工商业储能、电动汽车充电桩等新型电力设施大规模并网,传统 10kV 配电网正面临 “高渗透、强波动、多交互” 的运行挑战。2025 年 6 月 1 日正式实施的《配电网通用技术导则》(…...
推荐10个AI视频生成工具网站
以下是10个AI视频生成工具网站推荐: 国内工具 可灵:由快手AI团队研发,支持文生视频、图生视频、首尾帧设置和运镜调整等功能,生成视频画质高,适合短视频创作、AI唱跳、动画短片等。官网:可灵 即梦&#…...

TIA博途中的程序导出为PDF格式的具体方法示例
TIA博途中的程序导出为PDF格式的具体方法示例 如下图所示,选中想要导出为PDF的程序块,右击选择“打印”, 如下图所示,选择“导出为WPS PDF” 或者“Microsoft Print to PDF”, 如下图所示,设置文档布局相关…...

【大模型:知识图谱】--4.neo4j数据库管理(cypher语法1)
使用neo4j的cypher语法对图数据库进行管理;官网地址:Create, start, and stop databases - Operations Manual 目录 1.neo4j--简介 1.1.Neo4j版本的标准数据库 1.2.默认数据库 1.3.每用户主数据库 1.4.system数据库 2.neo4j--数据库管理 2.1.命名…...
Java 实现下拉框树状结构接口的核心思路
目录 核心思路 1. 定义树节点数据结构 : 2. 获取扁平化数据 : 3. 构建树形结构 : 4. 暴露接口 : TreeService.java:树形构建服务 解释 : 总结 下拉框(Dropdown)展示层级结构数…...

数字化时代养老机构运营实训室建设方案:养老机构运营沙盘实训模块设计
在数字化浪潮席卷各行各业的当下,养老机构运营实训室建设方案中的养老机构运营沙盘实训模块设计,已成为培养专业养老运营人才的关键环节,它需紧密贴合时代需求,构建兼具前瞻性与实用性的实训体系。点击获取实训室建设方案 一、养…...

自由开发者计划 004:创建一个苹果手机长截屏小程序
一. 背景 年初,一个漂亮姐姐突然问我,iphone这么多年一直没法长截屏,你们程序员就没个办法把这个硬伤补上吗? 虎躯一震,脑瓜子嗡嗡的,这么多年的iphone资深用户,最初也不是没有想过这个问题&am…...
【Go语言基础】基本语法
文章目录 一、 程序基本结构二. 词法标记(Lexical Tokens)(编译器解析单元)三、 标识符规则(变量命名规则)四、注释与行分隔符五、关键字与预定义标识符六、 代码示例解析 以下是基于文档的Go语言基础语法总…...

工作流引擎-18-开源审批流项目之 plumdo-work 工作流,表单,报表结合的多模块系统
工作流引擎系列 工作流引擎-00-流程引擎概览 工作流引擎-01-Activiti 是领先的轻量级、以 Java 为中心的开源 BPMN 引擎,支持现实世界的流程自动化需求 工作流引擎-02-BPM OA ERP 区别和联系 工作流引擎-03-聊一聊流程引擎 工作流引擎-04-流程引擎 activiti 优…...

【虚拟机版本号】如果忘记了版本号,这样查找版本号
【虚拟机版本号】如果忘记了版本号,这样查找版本号 找到虚拟机的文件: 然后用记事本打开这个:.vmx文件 然后搜索.version...
std::conditional_t一个用法
例子摘自: 《mastering-the-c17-stl-make-full-use-of-the-standard-library-components-in-c17.pdf》 struct list_node {int data;list_node *next; };template<bool Const> struct list_of_ints_iterator {friend class list_of_ints;friend class list…...
Java高效批量读取Redis数据:原理、方案与实战案例
Java高效批量读取Redis数据:原理、方案与实战案例 在电商大促场景中,某平台需要实时展示用户购物车数据,面对每秒10万的请求,传统单次读取Redis的方式导致响应延迟高达500ms。通过批量读取优化,最终将延迟降至20ms以内…...

基于RK3568的多网多串电力能源1U机箱解决方案,支持B码,4G等
基于RK3568的多网多串电力能源1U机箱解决方案,结合B码对时和4G通信能力,可满足电力自动化、能源监控等场景的高可靠性需求。核心特性如下: 一、硬件配置 处理器平台 搭载RK3568四核Cortex-A55处理器,主频1.8GHz-2.0GHz&#…...

面试题:Java多线程并发
继承 Thread 类 Thread 类本质上是实现了 Runnable 接口的一个实例,代表一个线程的实例。启动线程的唯一方法就是通过 Thread 类的 start()实例方法。start()方法是一个 native 方法,它将启动一个新线程,并执行 run()方法。 public class M…...

2006-2020年各省用水总量数据
2006-2020年各省用水总量数据 1、时间:2006-2020年 2、来源:国家统计局、统计年鉴 3、指标:行政区划代码、地区名称、年份、用水总量 4、范围:31省 5、指标说明:用水总量是指一个国家或地区在一定时期内ÿ…...

舵机在弹簧刀无人机中的作用是什么?
随着俄乌冲突的越发激烈,美国国防部宣布向乌克兰提供“弹簧刀”600型无人机。对于美国接连不断向乌克兰输送武器的做法,俄罗斯方面已经多次指责美国是在“火上浇油”,从而使俄乌冲突持续下去。 那么,弹簧刀究竟是一款怎样的无人机…...
c++ openssl 使用 DES(数据加密标准)进行加密和解密的基本操作
使用 DES(数据加密标准)进行加密和解密的基本操作,重点展示了 ECB 和 CBC 模式,并且通过篡改密文的方式来进行攻击。下面是对每个部分的详细解析。 1. 结构体 Slip struct Slip {char from[16] { 0 }; // 交易的发起者&#x…...

Git忽略规则.gitignore不生效解决
我在gitlab中新建了一个项目仓库,先把项目文件目录绑定到仓库,并全部文件都上传到了仓库中。 然后又从别的项目复制了忽略文件配置过来,怎么搞他都不能生效忽略我不要提交仓库的文件。 从网上查到说在本地仓库目录中,打开命…...
Excel高级函数使用FILTER、UNIQUE、INDEX
IFERROR(INDEX(UNIQUE(FILTER(明细表副本!B:B,(明细表副本!I:I>$B$1)*(明细表副本!I:I<$B$2)*(明细表副本!C:C<>$B$3)*(明细表副本!V:V$B$4))),ROW(明细表副本!B2)),"")解读 一、FILTER 过滤 FILTER(过滤列,过滤条件过滤条件) 过滤…...

6月5日day45
Tensorboard使用介绍 知识点回顾: tensorboard的发展历史和原理tensorboard的常见操作tensorboard在cifar上的实战:MLP和CNN模型 效果展示如下,很适合拿去组会汇报撑页数: 作业:对resnet18在cifar10上采用微调策略下&a…...
Linux 系统 rsyslog 配置
Linux 系统 rsyslog 配置指南 rsyslog 是 Linux 系统的下一代日志处理系统,功能强大且高效。以下是从基础到高级的全面配置指南: 1. 安装与基础配置 安装 rsyslog # Ubuntu/Debian sudo apt update sudo apt install rsyslog# CentOS/RHEL sudo yum …...

基于rpc框架Dubbo实现的微服务转发实战
目录 rpc微服务模块 导入依赖 配置dubbo 注解 开启Dubbo Dubbo的使用 特殊点 并没有使用 Reference 注入 微服务之间调用 可以选用Http 也可以Dubbo 我们 Dubbo 的实现需要一个注册中心 我作为一个服务的提供者 我需要把我的服务注册到注册中心去 调用方需要注册中心…...
matlab基于GUI实现水果识别
基于GUI实现水果识别系统,限一个图片内存在一种水果 图像处理是一种利用计算机分析图像以达到预期结果的技术。图像处理一般指数字图像处理,而数字图像指由工业相机、摄像机、扫描仪等设备捕捉到的二维数组,数组中的元素称为像素,…...