zoukankan      html  css  js  c++  java
  • Prometheus 监控平台的搭建

    1. 环境准备

     两台ubuntu 16.04

    服务器内网IP   作用   安装软件
    172.16.4.11                 监控的服务端                Prometheus(服务端软件) Grafana(数据展示)
    172.16.4.12 被监控的客户端

    node_exporter(收集服务器数据)

    mysqld_exporter(收集mysql数据)

     

     

     

     

     

     

     

    2. 客户端安装 node_exporter

     node_exporter 主要用于获取CPU,内存,IO,网络,硬盘等基础数据

     

       下载安装node_exporter

    #下载解压node_exporter
    wget https://github.com/prometheus/node_exporter/releases/download/v0.17.0/node_exporter-0.17.0.linux-amd64.tar.gz tar zxvf node_exporter-0.17.0.linux-amd64.tar.gz mv node_exporter-0.17.0.linux-amd64 /opt/node_exporter

     

    启动node_exporter

       cd /opt/node_exporter

    nohup ./node_exporter &

    查看启动端口

    tail -f 10 nohup.out

     

     设置允许端口访问  sudo ufw allow 9100

     可以在内网通过 http://172.16.4.12:9100/metrics 查看客户端数据

    3. 客户端安装 mysqld_exporter

     

      mysqld_exporter 主要监控Mysql数据库的稳定性、吞吐量、连接情况、缓冲池使用情况、查询性能等各项指标

     

     下载安装mysqld_exporter

     

    #下载解压mysqld_exporter
    wget https://github.com/prometheus/mysqld_exporter/releases/download/v0.11.0/mysqld_exporter-0.11.0.linux-amd64.tar.gz tar zxvf mysqld_exporter-0.11.0.linux-amd64.tar.gz mv mysqld_exporter-0.11.0.linux-amd64 /opt/mysqld_exporter

      

     配置数据库连接

     创建监控用的mysql用户

      mysql -u root -p

      输入root账号密码后,创建用户

     
    
    create user 'mysql_monitor'@'%' identified by 'monitor123456';
    
    grant replication client, process on *.* to mysql_monitor@"%" identified by "monitor123456";
    
    grant select on performance_schema.* to mysql_monitor@"localhost";

     进入mysqld_exporter安装目录创建.my.cnf配置文件

     

    cd /opt/mysqld_exporter
    vim .my.cnf

    添加如下配置

    [client]
    user=mysql_monitor
    password=monitor123456

    启动 mysqld_exporter

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

    查看启动端口

    tail -f nohup.out

     设置允许端口访问  sudo ufw allow 9104

     可以在内网通过 http://172.16.4.12:9104/metrics 查看mysql的相关监控数据

    4. 服务端安装 Prometheus

     

      安装 Prometheus

     

    sudo wget https://github.com/prometheus/prometheus/releases/download/v2.8.1/prometheus-2.8.1.linux-amd64.tar.gz
    tar zxvf  prometheus-2.8.1.linux-amd64.tar.gz
    mv  prometheus-2.8.1.linux-amd64  /opt/prometheus
    

      

     配置 Prometheus

     

    cd /opt/prometheus
    
    vi prometheus.yml

     在 配置文件中增加对客户端的节点和数据库的监控配置

    - job_name: 'mysql'
    static_configs:
    - targets: ['172.16.4.12:9104']
    labels:
    instance: 'db1'

    - job_name: 'node'
    static_configs:
    - targets: ['172.16.4.12:9100']
    labels:
    instance: 'nd1'

    截图如下

     

     启动 Prometheus

     

    nohup ./prometheus --config.file=./prometheus.yml &

    访问:http://172.16.4.11:9090/ 即可打开Prometheus 网页

     点击 Status --》 Target 即可看到我们的node和mysql的监控数据

     5. 安装可视化数据展示Grafana

     

     下载Grafana

    sudo apt-get -y install wget

    wget https://dl.grafana.com/oss/release/grafana_6.0.0-beta1_amd64.deb 

      sudo apt-get -f install

      sudo dpkg -i grafana_6.0.0-beta1_amd64.deb

    运行Grafana

    systemctl start grafana-server

    设置为开机启动

    sudo systemctl enable grafana-server

      

     打开3000端口

      

    sudo ufw allow 3000

     启动后可以通过 http://172.16.4.11:3000/ 访问 

     

     登录设置

     初始密码 admin/admin ,

      1. 添加一个data source ,使Grafana从Prometheus读取数据

     

     

     

      2. 导入对node监控的DashBoard

       首先去网站  https://grafana.com/grafana/dashboards 下载对主机监控的Dashboard

       搜素 Node Exporter

     

    点开第一个 ,拷贝对应的Dashboard Id  8919

     

     回到我们的图形监控平台Grafana,Dashboard ---> import 

     输入 dashboard ID 8919,选择数据源为prometheus即可

     

    3. 导入 mysql对应的监控面板 

    同上面的node监控面板一样,搜索关键字 mysql overview .找到对应的dashboard id  7362

     

     然后同上 添加Dashboard ---》 import 导入该面板

     到目前为止node和mysql的面板都导入成功

     

    4.  点击具体的面板即可查看具体的面板信息

      4.1  node面板

     

    4.2 mysql面板

    5. 插件安装

    上面的node面板,有个图片显示不全需要安装插件

    # 列出所有的可用插件

    grafana-cli plugins list-remote

    #安装我们需要的插件

    grafana-cli plugins install bargauge #插件安装后重启grafana
    systemctl restart grafana
    -server

    至此,对node和mysql的监控平台搭建完成,后续也可以配置一些alert,当符合一定条件时可以邮件或者钉钉通知告警

  • 相关阅读:
    Linux 系统下10个查看网络与监听的命令
    Linux下用gdb 调试、查看代码堆栈
    GPIO引脚速度的应用匹配
    编写安全的代码——小心有符号数的右移操作
    C语言实现类似C++的容器vector
    求字符串长度之递归与非递归的C语言实现
    字符串拷贝函数递归与非递归的C语言实现
    WriteLogHelper
    JsonHelper
    ConfigHelper
  • 原文地址:https://www.cnblogs.com/DevinZhang1990/p/12470702.html
Copyright © 2011-2022 走看看