• Prometheus+Grafana可视化监控【MySQL状态】


    一、安装Docker

    注意:我这里使用之前写好脚本进行安装Docker,如果已经有Docker请省略此步骤,安装Docker是为了方便部署MySQL数据库,如果已经有数据库前两步骤都可以省略。

    点击获取Docker离线安装脚本

    tar zxf docker20.10.14Install.tar.gz
    cd docker20.10.14Install
    bash install.sh
    
    • 1
    • 2
    • 3

    查看Docker状态如下图表示没问题:

    systemctl status docker
    
    • 1

    在这里插入图片描述

    二、安装MySQL数据库(Docker容器方式)

    1、前提准备:

    docker pull mysql:8.0.27
    mkdir /data/db -p
    
    systemctl stop firewalld
    systemctl disable firewalld
    iptables -F
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    2、运行容器:

    docker run -itd --name mysql -e MYSQL_ROOT_PASSWORD=NTQ34tg*@19VF \
    	 -v /data/db:/var/lib/mysql  -p 3306:3306 -v /etc/localtime:/etc/localtime \
    	  --restart=always mysql:8.0.27
    
    • 1
    • 2
    • 3

    3、测试容器是否可连接

    docker exec -it  mysql  mysql -uroot -pNTQ34tg*@19VF
    
    • 1

    当然可以使用工具测试连接,如下图:
    在这里插入图片描述

    只要保证保证数据库可以正常访问到即可!

    4、创建MySQL监控用户

    create user "prometheus"@"%" identified by 'NTQ34tg*@19VF';
    grant select,replication client,process ON *.* to "prometheus"@"%";
    flush privileges;
    
    • 1
    • 2
    • 3

    三、安装Prometheus

    1、时间和时区同步

    timedatectl set-timezone Asia/Shanghai
    yum -y install ntpdate
    /usr/sbin/ntpdate -u ntp1.aliyun.com
    
    • 1
    • 2
    • 3

    配置计划任务定时同步时间

    echo "0 5 * * * /usr/sbin/ntpdate -u ntp1.aliyun.com >/dev/null &" >> /var/spool/cron/root
    crontab -l
    
    • 1
    • 2

    2、安装Prometheus

    wget https://github.com/prometheus/prometheus/releases/download/v2.42.0/prometheus-2.42.0.linux-amd64.tar.gz
    
    tar zxf prometheus-2.42.0.linux-amd64.tar.gz 
    mv prometheus-2.42.0.linux-amd64 /usr/local/prometheus
    
    • 1
    • 2
    • 3
    • 4

    3、配置systemd管理

    cat > /usr/lib/systemd/system/prometheus.service << EOF
    [Unit]
    
    [Service]
    ExecStart=/usr/local/prometheus/prometheus --config.file=/usr/local/prometheus/prometheus.yml
    ExecReload=/bin/kill -HUP \$MAINPID
    
    [Install]
    WantedBy=multi-user.target
    Alias=dbus-org.fedoraproject.FirewallD1.service
    EOF
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    4、启动并设置开机自启

    systemctl enable prometheus --now
    systemctl status prometheus
    
    • 1
    • 2

    在这里插入图片描述
    显示如上图,表示Prometheus也没问题了,默认端口是9090,我们可以浏览器访问一下
    点击 Status > Targets 可以查看到Prometheus自己的metrics如下图:
    在这里插入图片描述

    四、安装Grafana

    1、安装Grafana

    wget https://dl.grafana.com/enterprise/release/grafana-enterprise-9.4.1-1.x86_64.rpm
    sudo yum install grafana-enterprise-9.4.1-1.x86_64.rpm -y
    
    systemctl enable grafana-server.service --now
    
    • 1
    • 2
    • 3
    • 4

    2、WEB页面验证
    默认端口是3000,第一次访问会提示重新设置密码,如下图:
    在这里插入图片描述
    在这里插入图片描述

    五、Pronetheus和Grafana相关联

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    六、安装mysqld_exporter

    1、安装mysqld_exporter

    wget https://github.com/prometheus/mysqld_exporter/releases/download/v0.14.0/mysqld_exporter-0.14.0.linux-amd64.tar.gz
    tar zxf mysqld_exporter-0.14.0.linux-amd64.tar.gz 
    mv mysqld_exporter-0.14.0.linux-amd64 /usr/local/mysqld_exporter
    
    • 1
    • 2
    • 3

    2、配置Prometheus监控数据库用户信息

    cd /usr/local/mysqld_exporter
    cat > .my.cnf <<EOF
    [client]
    user=prometheus
    password=NTQ34tg*@19VF
    EOF
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    3、配置systemd管理

    cat > /usr/lib/systemd/system/mysqld_exporter.service << EOF
    [Unit]
    Description=mysqld_exporter Service
    After=network.target
    
    [Service]
    Type=simple
    ExecStart=/usr/local/mysqld_exporter/mysqld_exporter --config.my-cnf=/usr/local/mysqld_exporter/.my.cnf
    ExecReload=/bin/kill -HUP \$MAINPID
    Restart=on-failure
    RestartSec=30s
    
    [Install]
    WantedBy=multi-user.target
    EOF
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    启动并加入开机自启动

    systemctl enable mysqld_exporter --now
    systemctl status  mysqld_exporter
    
    • 1
    • 2

    在这里插入图片描述

    默认端口为9104

    ss -anput |grep 9104
    
    • 1

    4、Prometheus配置文件中指定mysqld_exporter信息

    vim /usr/local/prometheus/prometheus.yml
    
      - job_name: "MySQL_115"
        static_configs:
          - targets: ["16.32.15.115:9104"]
    
    • 1
    • 2
    • 3
    • 4
    • 5

    添加完成配置文件后使用命令测试格式上是否有问题

    cd  /usr/local/prometheus/
    ./promtool check config prometheus.yml
    
    • 1
    • 2

    重启Prometheus

    systemctl restart prometheus.service
    
    • 1

    七、Grafana添加MySQL监控模板

    这里使用MySQL的模板ID:7362
    点击 下方红圈地方 > import > 输入模板ID
    在这里插入图片描述

    在这里插入图片描述
    最终效果图如下:
    在这里插入图片描述

  • 相关阅读:
    人工神经网络的拓扑结构,三层神经网络结构图
    【Java 进阶篇】JavaScript DOM Document对象详解
    【java学习—十四】java动态代理(6)
    融云「 IM 进阶实战高手课」系列直播上线
    【leetcode】【剑指offer Ⅱ】051. 节点之和最大的路径
    长沙兴盛优选C++面试指南(文字介绍加手写文档)
    design compiler中的drc规则详解
    数据结构之数组练习
    重要采样的原理与实现
    Service详解
  • 原文地址:https://blog.csdn.net/weixin_45310323/article/details/132841225