Prometheus是什么
Prometheus(普罗米修斯)是一个名字非常酷的开源监控系统。
它支持多维度的指标数据模型,服务端通过HTTP协议定时拉取数据后,通过灵活的查询语言,实现监控的目的。
如上图,客户端记录相关指标数据,对外提供查询接口。Prometheus服务端通过服务器发现机制找到客户端,并定时抓取存储为时间序列数据。最后通过Grafana等图表工具集成展示。
Prometheus可以做什么
-
在业务层用作埋点系统
Prometheus支持各个主流开发语言(Go,java,python,ruby官方提供客户端,其他语言有第三方开源客户端)。我们可以通过客户端方面的对核心业务进行埋点。如下单流程、添加购物车流程。 -
在应用层用作应用监控系统
一些主流应用可以通过官方或第三方的导出器,来对这些应用做核心指标的收集。如redis,mysql。 -
在系统层用作系统监控
除了常用软件, prometheus也有相关系统层和 络层exporter,用以监控服务器或 络。 -
集成其他的监控
prometheus还可以通过各种exporte,集成其他的监控系统,收集监控数据,如AWS CloudWatch,JMX,Pingdom等等。
不要用Prometheus做什么
prometheus也提供了Grok exporter等工具可以用来读取日志,但是prometheus是监控系统,不是日志系统。应用的日志还是应该走ELK等工具栈。
Prometheus 和 spring boot集成
- Prometheus中配置服务发现
-
maven中添加相关依赖
-
关闭spring boot原生metrics
-
Application类添加注解
@EnablePrometheusEndpoint
@EnableSpringBootMetricsCollector -
业务类定义埋点
static final Counter orderCount = Counter.build()
.name(“b2c_order_count”).help(“order count.”).labelNames(“shop”,”siteUid”).register(); -
业务埋点
orderCount.labels(“shein”,”mus”).inc();
Prometheus监控nginx
Prometheus可以通过nginx-lua-prometheus这个库对nginx进行埋点。
使用起来也非常简单:
但是,通过基准测试,发现使用了histogram类型的指标后,吞吐量会有5%-10%左右的降低。
总结
相关资料:
https://prometheus.io/
https://github.com/knyar/nginx-lua-prometheus
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!