各位伙伴,大家好!
Prometheus监控对于开发运维工程师来说并不陌生,但是对于测试工程师来说可能还是比较陌生吧!最近也很多小伙伴私信我问prometheus相关问题,所以接下来我会通过连载的方式分享一些关于prometheus如何使用的实践教程,欢迎大家持续关注并转发,如果需要相关教程资料可以私信我领取!
今天分享:Prometheus的六大核心组件!
概念:Prometheus(普罗米修斯)是一套开源的监控&报警&时间序列数据库的组合,它将所有信息都存储为时间序列数据;因此实现一种Profiling监控方式,实时分析系统运行的状态、执行时间、调用次数等,以找到系统的热点,为性能优化提供依据。
原理:Prometheus基本原理是通过HTTP协议周期性抓取被监控组件的状态,这样做的好处是任意组件只要提供HTTP接口就可以接入监控系统,不需要任何SDK或者其他的集成过程。这样做非常适合虚拟化环境比如VM或者Docker 。
(核心组件架构图)
核心组件说明:
1. Prometheus Server(核心服务器)
功能定位:数据采集、存储、查询与告警规则计算。
核心机制:
-
Pull 模型:主动从配置的目标(Targets)拉取指标(默认15秒间隔),减轻被监控方负担。
-
时间序列存储:
- 本地存储:按时间分片(默认2小时/块)存储于TSDB,支持高效压缩。
- 远程存储:支持对接Thanos、Cortex等长期存储方案,解决海量数据扩容问题。
-
告警规则引擎:基于PromQL定义规则(如ALERT Hi