监控简介
- prometheus是由SoundCloud开源的监控报警解决方案
- 采用go语言开发
- prometheus存储的是时序数据
- 数据带时间标签
- Prometheus主要用在监控容器数据 也可以监控常规主机
- Prometheus重视高可用 如果您需要100%准确性 那么该软件不适合您 因为它所收集的数据可能不会足够详细和完整
- Prometheus是一个框架 可以与其他组件完美组合
部署Prometheus服务器
- 环境说明:
- Prometheus 192.168.88.5
- web1 192.168.88.100
1.配置时间
2.安装Prometheus服务器
- 1 拷贝相关软件包到服务器
- 2.解压即部署
配置文件
- 配置文件中包含三个配置块:
global
、rule_files
和scrape_configs
。 global
块控制 Prometheus 服务器的全局配置。我们有两个选择。第一个,scrape_interval
控制 Prometheus 抓取目标的频率。您可以为单个目标覆盖它。在这种情况下,全局设置是每 15 秒抓取一次。该evaluation_interval
选项控制 Prometheus 评估规则的频率。Prometheus 使用规则来创建新的时间序列并生成警报。rule_files
块指定我们希望 Prometheus 服务器加载的任何规则的位置。现在我们还没有规则。- 最后一个块,
scrape_configs
控制 Prometheus 监控的资源。由于 Prometheus 还将有关自身的数据公开为 HTTP 端点,因此它可以抓取和监控自身的健康状况。在默认配置中,有一个名为 的作业prometheus
,用于抓取 Prometheus 服务器公开的时间序列数据。该作业包含一个单一的、静态配置的目标,即localhost的9090
端口。Prometheus期望度量在/metrics路径上的目标上可用,所以这个默认作业是通过 URL 抓取的:http://localhost:9090/metrics。 - 编写服务启动文件并启动服务
- 访问web页面: http://192.168.88.5:9090/
添加被监控端
- 监控方式:
- 拉取:pull。监控端联系被监控端,采集数据
- 推送:push。被监控端主动把数据发给监控端。在prometheus中,push的方式需要额外的组件pushgateway
- 被监控端根据自身运行的服务,可以运行不同的exporter(被监控端安装的、可以与Prometheus通信,实现数据传递的软件)
- exporter列表: https://prometheus.io/docs/instrumenting/exporters/
部署通用的监控exporter
- node-exporter用于监控硬件和系统的常用指标
- exporter运行于被监控端,以服务的形式存在。每个exporter所使用的端口号都不一样。
- 在web1[192.168.88.100]上部署node exporter
- 在Prometheus服务器上添加监控节点
- 查看添加结果
Grafana
概述
- Grafana是一款开源的、跨平台的、基于web的可视化工具
- 展示方式:客户端图表、面板插件
- 数据源可以来自于各种源,如prometheus
部署Grafana
- 装包、启服务
- 初始化。访问 http://192.168.88.5:3000。初始用户名和密码都是admin。第一次登陆时,要求改密码,本例中密码改为tedu.cn。如果登陆报错,请更换其他浏览器。
- 修改主题
- 对接Prometheus
- 添加仪表盘
- 查看仪表盘
所有评论(0)