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

 

 Prometheus 监控平台的搭建_第1张图片

 

 设置允许端口访问  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

 

Prometheus 监控平台的搭建_第2张图片

 

 

 设置允许端口访问  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 监控平台的搭建_第3张图片

 启动 Prometheus

 

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

 

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

 

Prometheus 监控平台的搭建_第4张图片

 

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

 

Prometheus 监控平台的搭建_第5张图片

 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/ 访问 

 

 Prometheus 监控平台的搭建_第6张图片

 

 

 

 登录设置

 

 初始密码 admin/admin ,

 

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

 

 Prometheus 监控平台的搭建_第7张图片

 

 

 

 

 Prometheus 监控平台的搭建_第8张图片

 

 

 

 Prometheus 监控平台的搭建_第9张图片

 

 

 

  2. 导入对node监控的DashBoard

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

   搜素 Node Exporter

 

 Prometheus 监控平台的搭建_第10张图片

 

 

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

 

Prometheus 监控平台的搭建_第11张图片

 

 

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

 

Prometheus 监控平台的搭建_第12张图片

 

 

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

 

 Prometheus 监控平台的搭建_第13张图片

 

 

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

 

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

 

Prometheus 监控平台的搭建_第14张图片

 

 

 Prometheus 监控平台的搭建_第15张图片

 

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

 

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

 Prometheus 监控平台的搭建_第16张图片

 

 

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

  4.1  node面板

 

 Prometheus 监控平台的搭建_第17张图片

 

 

4.2 mysql面板

Prometheus 监控平台的搭建_第18张图片

 

 

 

5. 插件安装

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

 

# 列出所有的可用插件

grafana-cli plugins list-remote

#安装我们需要的插件

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

 

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

你可能感兴趣的:(Prometheus 监控平台的搭建)