前言
最近想要配置Spring Boot应用Prometheus+Grafana监控的demo,发现网上的很多中英文资料,内容过时或者配置不对。
因此写一个文章来说明整个体系是怎么工作的。
Demo的源码地址:
-
https://github.com/hengyunabc/spring-boot-prometheus-grafana-demo
spring boot应用metrics配置
首先,我们直接到官网创建一个spring boot demo应用:
-
https://start.spring.io/
创建好后,我们在 pom.xml 里加入下面的依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>io.micrometer</groupId>
<artifactId>micrometer-registry-prometheus</artifactId>
</dependency>
-
spring-boot-starter-actuator 支持spring boot暴露http endpoint
-
micrometer-registry-prometheus 支持prometheus endpoint,这个暴露的是
OpenMetrics的格式,prometheus从这里采集数据。
再看下 application.properties 文件:
spring.application.name=expose-prometheus-demo
server.port=8080
management.endpoints.web.exposure.include=*
management.server.port=8090
management.metrics.tags.application=${spring.application.name}
-
management.server.port配置endpoint为独立端口,和应用混用同一端口容易有安全问题 -
management.metrics.tags.application配置metric里application</

本文详细介绍了如何配置Spring Boot应用使用Prometheus和Grafana进行监控,包括添加必要依赖,配置Kubernetes环境,发布应用到K8s,以及配置Grafana展示监控数据。过程中提到了配置坑点和解决方法,强调了Prometheus Operator的自动发现和更新机制。
最低0.47元/天 解锁文章
1135

被折叠的 条评论
为什么被折叠?



