当前位置: 首页 > news >正文

mysqld_exporter的搭建

1、创建/data/apps目录,并且下载mysql_exporte

mkdir -p /data/apps
​
cd /data/apps
​
wget https://githubfast.com/prometheus/mysqld_exporter/releases/download/v0.12.1/mysqld_exporter-0.12.1.linux-amd64.tar.gz
或者
wget https://github.com/prometheus/mysqld_exporter/releases/download/v0.12.1/mysqld_exporter-0.12.1.linux-amd64.tar.gz

2、解压压缩包到/usr/local,并且重创建软链接

tar -zxvf mysqld_exporter-0.12.1.linux-amd64.tar.gz -C /usr/local
​
cd /usr/local
​
ln -s mysqld_exporter-0.12.1.linux-amd64 mysqld_exporter
​

3、使用systemctl管理mysqld_exporter

vi /usr/lib/systemd/system/mysqld_exporter.service
​
[Unit]
​
Description=Prometheus
​
[Service]
​
Environment=DATA_SOURCE_NAME=exporter:Prometheus@(localhost:3306)/
ExecStart=/usr/local/mysqld_exporter/mysqld_exporter --config.my-cnf=/usr/local/mysqld_exporter/.my.cnf --web.listen-address=:9104
Restart=on-failure
​
[Install]
​
WantedBy=multi-user.target
​

4、设置开机自启并且开启mysqld_exporter服务,数据库进行添加用户和放开权限

systemctl enable mysqld_exporter && systemctl start mysqld_exporter && systemctl status mysqld_exporter
​
iptables -I INPUT -p tcp --dport 9104 -j ACCEPT &&
iptables-save
​
数据库的操作
​
cd /usr/local/mysqld_exporter
​
cat > .my.cnf <<EOF
[client]
user=exporter
password=Prometheus
EOF
​
mysql -u root -p
​
set global validate_password_policy=LOW;  
​
CREATE USER 'exporter'@'localhost' IDENTIFIED BY 'Prometheus' WITH MAX_USER_CONNECTIONS 5;
​
GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO 'exporter'@'localhost';
​

5、在prometheus服务器添加mysqld_exporter节点监控

vi /usr/local/prometheus/prometheus.yml
​
  - job_name: "mysqld_exporter"
    static_configs:
      - targets: ['被监控设备的IP:9104']
        labels:
          app: mysqld_exporter
          role: mysqld_exporter
      
或者以file_sd_configs方式添加node
vi /usr/local/prometheus/prometheus.yml
​
  - job_name: "mysqld_exporter"
    file_sd_configs:
      - files:
        - /usr/local/prometheus/target/mysqld_exporter.yml
        
# pwd
/usr/local/prometheus/target
# cat mysqld_exporter.yml 
- targets:
  - "被监控设备的IP:9104"
  labels:
    app: mysqld_exporter
    role: mysqld_exporter
​

6、热加载prometheus配置

curl  -X POST http://127.0.0.1:9090/-/reload
​
脚本方式部署
----------------------------------------------------------------------------
mysqld_exporter节点

vi mysqld_exporter.sh
​
#!/bin/bash
​
setenforce 0 &&
iptables -I INPUT -p tcp --dport 9104 -j ACCEPT &&
iptables-save > /dev/null  &&
mkdir -p /data/apps > /dev/null &&
cd /data/apps &&
wget https://githubfast.com/prometheus/mysqld_exporter/releases/download/v0.12.1/mysqld_exporter-0.12.1.linux-amd64.tar.gz > /dev/null &&
echo "下载mysqld_exporter压缩包完成" &&
tar -zxvf mysqld_exporter-0.12.1.linux-amd64.tar.gz -C /usr/local > /dev/null &&
cd /usr/local &&
ln -s mysqld_exporter-0.12.1.linux-amd64 mysqld_exporter &&
echo "[Unit]
​
Description=Prometheus
​
[Service]
​
Environment=DATA_SOURCE_NAME=exporter:Prometheus@(localhost:3306)/
ExecStart=/usr/local/mysqld_exporter/mysqld_exporter --config.my-cnf=/usr/local/mysqld_exporter/.my.cnf --web.listen-address=:9104
Restart=on-failure
​
[Install]
​
WantedBy=multi-user.target" | tee -i /usr/lib/systemd/system/mysqld_exporter.service > /dev/null &&
systemctl enable mysqld_exporter && 
systemctl start mysqld_exporter && 
systemctl status mysqld_exporter 
​
sh ./mysqld_exporter.sh

​进行上面4的数据库的操作

卸载mysqld_exporter节点

vi mysqld_exporter_uninstall.sh
​
#!/bin/bash
​
systemctl disable mysqld_exporter && 
systemctl stop mysqld_exporter && 
rm -rf /usr/lib/systemd/system/mysqld_exporter.service &&
setenforce 1 &&
iptables -D INPUT -p tcp --dport 9104 -j ACCEPT &&
iptables-save > /dev/null  &&
cd /usr/local &&
unlink mysqld_exporter &&
rm -rf mysqld_exporter-0.12.1.linux-amd64 &&
rm -rf /data/apps/mysqld_exporter-0.12.1.linux-amd64.tar.gz > /dev/null &&
echo "删除mysqld_exporter压缩包完成" 
​
sh ./mysqld_exporter_uninstall.sh
​

​prometheus节点

vi mysqld_exporter_join.sh
​
#!/bin/bash
​
#对应被监控的node名称
NODENAME=$1
#对应被监控的IP地址
IPADDRESS=$2
echo "
  - job_name: "$NODENAME"
    static_configs:
      - targets: ["$IPADDRESS:9104"]
    " | tee -a /usr/local/prometheus/prometheus.yml > /dev/null &&
/usr/local/prometheus/promtool check config /usr/local/prometheus/prometheus.yml &&
curl  -X POST http://127.0.0.1:9090/-/reload
​
sh ./mysqld_exporter_join.sh NODENAME(对应被监控的node名称) IPADDRESS(对应被监控的IP地址)
​

相关文章:

  • webstorm提示ESlint: please specify Node.js interpreter
  • 前端面试手写--虚拟列表
  • Python实现语音识别详细教程【2025】最新教程
  • Ollama 开发指南
  • 应用层协议 HTTP 讲解实战:从0实现HTTP 服务器
  • Ubuntu 下 nginx-1.24.0 源码分析 - ngx_time_update函数
  • NAC网络接入控制三种认证方式802.1X认证、MAC认证和Portal认证
  • Python 文本探秘:正则表达式的易错迷宫穿越 -- 7. 正则表达式
  • 模糊聚类分析方法:从模糊等价矩阵到动态分类
  • 笔记: 利用二极管、三极管、MOS管搭建过压保护电路
  • vitePress实现原理(三)
  • 使用 Logback 的最佳实践:`logback.xml` 与 `logback-spring.xml` 的区别与用法
  • DIN:引入注意力机制的深度学习推荐系统,
  • Golang官方编程指南
  • 从安装软件到flask框架搭建可视化大屏(一)——创建一个flask页面,零基础也可以学会
  • Linux从0到1——线程池【利用日志Debug】
  • Elasticsearch:将 Ollama 与推理 API 结合使用
  • 【第11章:生成式AI与创意应用—11.3 AI艺术创作的实现与案例分析:DeepArt、GANBreeder等】
  • Leetcode 2466. Count Ways To Build Good Strings
  • 【Day41 LeetCode】单调栈问题
  • 来论|受美国“保护”,日本民众要付出什么代价?
  • A股三大股指涨跌互现:3343股收涨,两市成交超1.1万亿元
  • 朝鲜海军新型驱逐舰进行首次武器系统测试
  • 《求是》杂志发表习近平总书记重要文章《激励新时代青年在中国式现代化建设中挺膺担当》
  • 美财长称关税战升级的责任在中方,外交部:关税战、贸易战没有赢家
  • 国家统计局:一季度全国规模以上文化及相关产业企业营业收入增长6.2%