目录
工程简介
总体框架图
![](https://i-blog.csdnimg.cn/blog_migrate/490ba28d439a9ce23eba169da9936d8d.png)
简介
Prometheus
Prometheus,是一个开源的系统监控和告警的工具包,其采用Pull方式采集时间序列的度量数据(也支持push方式),通过Http协议传输。它的工作方式是被监控的服务需要公开一个Prometheus端点,这端点是一个HTTP接口,该接口公开了度量的列表和当前的值,然后Prometheus应用从此接口定时拉取数据,一般可以存放在时序数据库中,然后通过可视化的Dashboard(e.g.Grafana)进行数据展示。
支持的prometheus metrics
Counter,Gauge,Histogram,Summary,untyped等等。需要注意的是counter只能增不能减,适用于服务请求量,用户访问数等统计,但是如果需要统计有增有减的指标需要用Gauge。
exporter
支持的 exporter 很多,可以方便的监控很多应用,同时也可以自定义开发非官方提供的exporter。
grafana
grafana,是一个开源的dashboard展示工具,可以支持很多主流数据源,包括时序性的和非时序性的。其提供的展示配置以及可扩展性能满足绝大部分时间序列数据展示需求,是一个比较优秀的工具。
支持的数据源
prometheus,inflexdb,elasticsearch,mysql,postgreSQL,openTSDB等,更多数据源:Grafana Plugins - extend and customize your Grafana | Grafana Labs
SpringBoot工程初始化
springboot加速初始化:https://start.aliyun.com/
![](https://i-blog.csdnimg.cn/blog_migrate/134880759b1b838789099efe28078c6e.png)
添加依赖
pom.xml
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>io.micrometer</groupId> <artifactId>micrometer-registry-prometheus</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
配置信息
在application.yml增加以下配置项
##SpringBoot2.x整合Prometheus+Grafana ##源码:https://github.com/Rodert/SpringBoot-javapub management: metrics: export: prometheus: enabled: true step: 1m descriptions: true web: server: auto-time-requests: true endpoints: prometheus: id: springmetrics web: exposure: include: health,info,env,prometheus,metrics,httptrace,threaddump,heapdump,springmetrics server: port: 8080
启动SpringBoot应用
http://localhost:8080/actuator/prometheus
打开即可看到暴露的信息
环境安装
如安装包下载不成功,可以在公众号回复【prometheus安装包】or【grafana安装包】领取
Prometheus安装
修改配置:
prometheus.yml
# my global config global: scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute. evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute. # scrape_timeout is set to the global default (10s). # Alertmanager configuration alerting: alertmanagers: - static_configs: - targets: # - alertmanager:9093 # Load rules once and periodically evaluate them according to the global 'evaluation_interval'. rule_files: # - "first_rules.yml" # - "second_rules.yml" # A scrape configuration containing exactly one endpoint to scrape: # Here it's Prometheus itself. scrape_configs: # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config. - job_name: 'prometheus' # metrics_path defaults to '/metrics' # scheme defaults to 'http'. #暴露路径 metrics_path: /actuator/prometheus static_configs: #SpringBoot的ip和端口号 - targets: ['localhost:8080']
启动Prometheus
prometheus.exe
![](https://i-blog.csdnimg.cn/blog_migrate/dbe01f6f9f602a5b4a5c669292932662.png)
测试访问
![](https://i-blog.csdnimg.cn/blog_migrate/484b95664980f1e5fae318c07143badc.png)
jvm_memory_used_bytes
![](https://i-blog.csdnimg.cn/blog_migrate/90b64dc97586cf4f59363f3c1ebddeec.png)
Grafana安装
![](https://i-blog.csdnimg.cn/blog_migrate/722dad962ea15fcfe6d82de1ca595a41.png)
启动grafana
![](https://i-blog.csdnimg.cn/blog_migrate/e1b1cedc1e302bdce3ce2f9ebaaa180d.png)
测试
![](https://i-blog.csdnimg.cn/blog_migrate/2f9552b47b7878f3f1484e72a0d250fe.png)
默认账号:admin 密码:admin
![](https://i-blog.csdnimg.cn/blog_migrate/2175a8cc4ac5e09fa11993f8ac77d16b.png)
整合
增加数据源
![](https://i-blog.csdnimg.cn/blog_migrate/12e3c0f6b9f6cf8305858bb5d93af6a3.png)
![](https://i-blog.csdnimg.cn/blog_migrate/b87ce6c4a9058b32d8fa5b678fd14299.png)
- Name填一个
- URL填的Prometheus访问地址
![](https://i-blog.csdnimg.cn/blog_migrate/6abc0acc2bfb886656159af504546a77.png)
添加图表
![](https://i-blog.csdnimg.cn/blog_migrate/e7c3da4446d708043cd103f3fa46d4c8.png)
指定数据源、指定监控指标 jvm_memory_used_bytes
![](https://i-blog.csdnimg.cn/blog_migrate/18bdcf69b82be945f82fb7dad706550c.png)
切换图标
![](https://i-blog.csdnimg.cn/blog_migrate/df6f25886b50ef496266bf71d88cb4ec.png)
![](https://i-blog.csdnimg.cn/blog_migrate/922df16d5feb2fff8893736126c08c08.png)
源码地址:GitHub - Rodert/spring-boot-prometheus-grafana: springboot2.x整合prometheus+grafana【附源码+视频+文档】