Prometheus
Prometheus
Prometheus是一个开源系统监控和警报工具包。
现在是一个独立的开源项目,独立于任何公司进行维护。
Prometheus基本原理是通过HTTP协议周期性抓取被监控组件的状态,这样做的好处是任意组件只要提供HTTP接口就可以接入监控系统,不需要任何SDK或者其他的集成过程。这样做非常适合虚拟化环境比如VM或者Docke。
Prometheus 将其指标收集并存储为时间序列数据,即指标信息与记录的时间戳一起存储,以及称为标签的可选键值对。
大多数 Prometheus 组件都是用Go编写的,这使得它们易于构建和部署为静态二进制文件。
官方文档:https://prometheus.io/docs/introduction/overview/
Prometheus 的架构及其一些生态系统组件:
准备环境
两台虚拟机,OS为rhel7.6版本
server7 192.168.122.17 监控端(也监控自己)
server8 192.168.122.18 被监控端
部署Prometheus
监控端:
下载安装包:
Prometheus安装包:
wget https://github.com/prometheus/prometheus/releases/download/v2.3.2/prometheus-2.3.2.linux-amd64.tar.gz
go语言包:
wget https://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gz
解压go语言包并将其添加至环境变量
tar -C /usr/local -xzf go1.8.3.linux-amd64.tar.gz
echo "export PATH=$PATH:/usr/local/go/bin" >> /etc/profile
source /etc/profile
解压Prometheus安装包并建立软链接
tar -zxf prometheus-2.3.2.linux-amd64.tar.gz -C /usr/local/
ln -sv /usr/local/prometheus-2.3.2.linux-amd64/ /usr/local/Prometheus
编辑prometheus配置文件
vim /usr/local/prometheus-2.3.2.linux-amd64/prometheus.yml
#监听地址为本机9090端口
#设置监听server8节点,端口为9100
后台运行prometheus
/usr/local/Prometheus/prometheus --config.file=/usr/local/Prometheus/prometheus.yml &
被监控端
下载安装包:
node_exporter包:
wget https://github.com/prometheus/node_exporter/releases/download/v0.16.0/node_exporter-0.16.0.linux-amd64.tar.gz
可以去官网下载最新版:https://prometheus.io/download/
解压并改个名字方便之后运行
tar -zxvf node_exporter-0.16.0.linux-amd64.tar.gz -C /usr/local/
mv /usr/local/node_exporter-0.16.0.linux-amd64/ /usr/local/node_exporter
后台运行node_exporter
/usr/local/node_exporter/node_exporter &
测试
在浏览器输入监控端ip及端口进行访问,进入页面如下
查看目标可以看到监控的两个目标(自己和server8)
也可以查看服务发现
点击端点url可以查看详细信息
server7的信息
server8的信息