Prometheus mysqld_exporter 监控mysql配置方法

Prometheus mysqld_exporter 支持MySQL服务的监控指标

支持的版本:

  • MySQL >= 5.6.
  • MariaDB >= 10.3

一、首先

在配置mysqld_exporter监控之前,我们需要先创建一个监控帐号,用于后面连接数据库使用

sql 复制代码
CREATE USER 'exporter'@'localhost' IDENTIFIED BY 'XXXXXXXX' WITH MAX_USER_CONNECTIONS 3;
GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO 'exporter'@'localhost';

备注好创建的数据库帐号密码。

二、搭建mysqld_exporter

我们这边举例使用预编译的安装包,可通过官网下载

为了偷懒,写了一个自动部署的脚本,如下:

bash 复制代码
#!/bin/bash
# Author by huwj

ipath="/usr/local"
appname="mysqld_exporter"
filename="0.15.1.linux"
unamem=`uname -m`
if [[ ${unamem} == "x86_64" ]];then
    version="${filename}-amd64"
else
    version="${filename}-arm64"
fi
install()
{
    if [ ! -d "${ipath}/${appname}" ];then
        echo "压缩包解压中 ... ..."
        tar -zxvf ${appname}-${version}.tar.gz >/dev/null 2>&1
        mv ${appname}-${version} ${ipath}/${appname}
        if [ $? -ne 0 ]; then
            echo "${appname} 安装失败!"
            rm -rf ${appname}-${version}
        else
            cp ${appname}.service /usr/lib/systemd/system/
            if [[ $? -ne 0 ]];then
                echo "${appname} 安装失败!"
            else
                systemctl enable ${appname}
                systemctl start ${appname}
                echo "${appname} 安装成功!"
            fi
        fi
    else
        echo "${ipath} 目录下${appname}已存在,请确认后重新安装!"
        rm -rf ${appname}-${version}
    fi
}
install;

以上对应的 mysqld_exporter.service 脚本如下:

bash 复制代码
[Unit]
Description=mysqld_exporter
Documentation=https://prometheus.io/
After=network.target

[Service]
Type=simple
User=root
Group=root
ExecStart=/usr/local/mysqld_exporter/mysqld_exporter --config.my-cnf=/etc/prometheus/.my.cnf
Restart=on-failure

[Install]
WantedBy=multi-user.target

配置数据库的帐号信息,新建文件 /etc/prometheus/.my.cnf

bash 复制代码
[client]
user="foo"
password="foo123"
# host="127.0.0.1" # 如果是在本机可以不配置

web端口默认是9104,如果需要更换端口可以在启动参数加上 --web.listen-address=端口号

完成以上信息配置,重启mysqld_exporter 服务

bash 复制代码
systemctl restart mysqld_exporter

然后需要验证下,服务是否正常启动并监控到数据

bash 复制代码
curl http://localhost:9104/metrics

查看监控指标是否有返回mysql的相关信息

如果有数据,就说明配置成功!

三、参考文献

GitHub - prometheus/mysqld_exporter: Exporter for MySQL server metrics

相关推荐
念越35 分钟前
MySQL报错:Column count doesn‘t match value count at row 1 解决方案(超详细)
数据库·mysql
SmartBrain1 小时前
FastAPI实战(第二部分):用户注册接口开发详解
数据库·人工智能·python·fastapi
倔强的石头_2 小时前
一卡通核心交易平台的国产数据库实践解析:架构、迁移与高可用落地
数据库
952362 小时前
MySQL存储过程和触发器
数据库·mysql
x***r1512 小时前
phpstudy_x64_8.1.1.3安装教程(含Apache/MySQL启动与端口修改)
数据库·mysql·apache
AC赳赳老秦2 小时前
2026 AI原生开发工具链趋势:DeepSeek与主流IDE深度联动实践指南
运维·ide·人工智能·架构·prometheus·ai-native·deepseek
笨蛋不要掉眼泪2 小时前
Sentinel 流控规则详解:三种模式与三种效果实战指南
java·jvm·数据库·后端·sentinel
cjl_8520083 小时前
MySQL-递归查询
数据库·windows·mysql
一个响当当的名号3 小时前
lectrue15 并发控制理论
数据库
野犬寒鸦3 小时前
Java8 ConcurrentHashMap 深度解析(底层数据结构详解及方法执行流程)
java·开发语言·数据库·后端·学习·算法·哈希算法