Prometheus

1、Prometheus 概述

Prometheus(普罗米修斯)是一套开源的监控&报警&时间序列数据库的组合,起始是由SoundCloud 公司开发的。现在最常见的 Docker、Mesos、Kubernetes 容器管理系统中,通常会搭配Prometheus 进行监控。

  • Prometheus 基本原理是通过 HTTP 协议周期性抓取被监控组件的状态,这样做的好处是任意组件只要提供 HTTP 接口就可以接入监控系统,不需要任何 SDK 或者其他的集成过程。这样做非常适合虚拟化,环境比如 VM 或者 Docker 。
  • 输出被监控组件信息的 HTTP 接口被叫做 exporter。目前互联网公司常用的组件大部分都有
    exporter 可以直接使用,比如 Varnish、Haproxy、Nginx、MySQL、Linux 系统信息 (包括磁盘、
    内存、CPU、网络等等),具体支持的源看:https://github.com/prometheus

2、Prometheus 架构图解

python prometheus监控平台 prometheus web监控_mysql


Prometheus 各组件运行流程如下:

  • 1、Prometheus Server:Prometheus Sever 是 Prometheus 组件中的核心部分,负责实现对监控数据的获取,存储及查询。Prometheus Server 可以通过静态配置管理监控目标,也可以配合使用Service Discovery(服务发现)的方式动态管理监控目标,并从这些监控目标中获取数据。其次Prometheus Sever 需要对采集到的数据进行存储,Prometheus Server 本身就是一个实时数据库,将采集到的监控数据按照时间序列的方式存储在本地磁盘当中。Prometheus Server 对外提供了自义的PromQL,实现对数据的查询以及分析。另外 Prometheus Server 的联合集群能力可以使其从其他的Prometheus Server 实例中获取数据。
  • 2、Exporters:Exporter将监控数据采集的端点通过 HTTP 服务的形式暴露给Prometheus Server,Prometheus Server 通过访问该 Exporter 提供的 Endpoint 端点,即可以获取到需要采集的监控数据。
    可以将 Exporter 分为 2 类:
  • (1)、直接采集:这一类 Exporter 直接内置了对 Prometheus 监控的支持,比如 cAdvisor,Kubernetes,Etcd,Gokit 等,都直接内置了用于向 Prometheus 暴露监控数据的端点。
  • (2)、间接采集:原有监控目标并丌直接支持 Prometheus,因此需要通过 Prometheus 提供的 Client Library 编写该监控目标的监控采集程序。例如:Mysql Exporter,JMX Exporter,Consul Exporter等。
  • 3、AlertManager:在 Prometheus Server 中支持基于 Prom QL 创建告警原则,如果满足 Prom QL 定义的觃则,则会产生一条告警。常见的接收斱方式有:电子邮件,webhook 等。
  • 4、PushGateway:Prometheus 数据采集基于 Prometheus Server 从 Exporter pull 数据,因此当网络环境允许 Prometheus Server和 Exporter 进行通信时,可以使用 PushGateway 来进行中转。
    AlertManager:在 Prometheus Server 中支持基于 Prom QL 创建告警,如果满足 Prom QL 定义的觃则,则会产生一条告警。常见的接收斱式有:电子邮件,webhook 等。

3、Prometheus 的工作流程

  • 1、Prometheus server 定期从配置好的 jobs 和 exporters 中拉取 metrics,或者接收来自Pushgateway 发送过来的 metrics,或者从其它的 Prometheus server 中拉metrics。
  • 2、Prometheus server 在本地存储收集到的 metrics,并运行定义好的 alerts.rules,记录新的时间序列或者向 Alert manager 推送警报。
  • 3、Alertmanager 根据配置文件,对接收到的警报进行处理,发出告警。
  • 4、在图形界面中,可规化采集数据。

4、搭建Prometheus过程

  • 步骤一:配置epel源



    步骤二:安装并且配置Prometheus
yum install go -y       #安装go语言,因为Prometheus是用go语言写的
tar zxvf prometheus-2.7.1.linux-amd64.tar.gz -C /usr/local/
cd /usr/local/
cd prometheus-2.7.1.linux-amd64/
vim prometheus.yml

 30   - job_name: system-status  #每一个job_name都是一个监控项,这里代表监控操作系统状态
 31     static_configs:
 32       - targets: ['192.168.0.103:9100']   #被监控主机IP地址和端口
 33         labels:
 34           instance: server3     #实例名称,在grafana中表示对应的主机
 35 
 36   - job_name: mysql-status   #监控mysql数据库状态
 37     static_configs:
 38       - targets: ['192.168.0.103:9104']   #目标主机IP地址和端口
 39         labels:
 40           instance: server3-mysql  #实例名称,在 grafana 中表示对应的主机

python prometheus监控平台 prometheus web监控_Server_02


python prometheus监控平台 prometheus web监控_Server_03

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

python prometheus监控平台 prometheus web监控_数据_04

  • 步骤三:在浏览器中输入http://192.168.0.102:9090
  • 步骤四:启动用于采集linux系统的exporter服务
  • 步骤五:在server3上安装数据库,并且配置mysqld_exporter用于监控 server3上的mysql服务
yum install -y mariadb-server mariadb 
systemctl start mariadb
mysql_secure_installation
mysql -uroot -predhat
GRANT REPLICATION CLIENT,PROCESS ON *.* TO 'mysql_monitor'@'localhost' 
    -> identified by '123456';

python prometheus监控平台 prometheus web监控_mysql_05


python prometheus监控平台 prometheus web监控_Server_06


python prometheus监控平台 prometheus web监控_mysql_07


在 web 界面,再次查看监控信息已经成功添加linux和mysql节点,已经up了

python prometheus监控平台 prometheus web监控_mysql_08