学习笔记-JVM监控平台搭建

SpringBoot Actuator

1 引入依赖

xml 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

2 开启配置

bash 复制代码
# 暴露所有的监控点【含Prometheus】
management.endpoints.web.exposure.include: *
# 定义Actuator访问路径
management.endpoints.web.base-path: /actuator
# 开启endpoint 关闭服务功能
management.endpoint.shutdown.enabled: true

3 访问
http://127.0.0.1:8888/actuator

4 提供的信息如下表

路径 描述 默认开启
/beans 显示容器的全部的Bean,以及它们的关系 Y
/env 获取全部环境属性 Y
/env/{name} 根据名称获取特定的环境属性值 Y
/health 显示健康检查信息 Y
/info 显示设置好的应用信息 Y
/mappings 显示所有的@RequestMapping信息 Y
/metrics 显示应用的度量信息 Y
/scheduledtasks 显示任务调度信息 Y
/httptrace 显示Http Trace信息 Y
/caches 显示应用中的缓存 Y
/conditions 显示配置条件的匹配情况 Y
/configprops 显示@ConfigurationProperties的信息 Y
/loggers 显示并更新日志配置 Y
/shutdown 关闭应用程序 N
/threaddump 执行ThreadDump Y
/headdump 返回HeadDump文件,格式为HPROF Y
/prometheus 返回可供Prometheus抓取的信息 Y

Micrometer

Spring Boot 2.0以上,使用了micrometer作为底层的度量工具,micrometer是监控度量的门面,它能支持按照各种格式来暴露数据,其中就有Prometheus。

1 引入依赖

xml 复制代码
<dependency>
    <groupId>io.micrometer</groupId>
    <artifactId>micrometer-registry-prometheus</artifactId>
</dependency>

这个依赖的作用就是会开启一个endpoint,输出兼容Prometheus exporter的结果,方便Prometheus来采集。

2 进行配置

bash 复制代码
server.port: 8888
spring.application.name: deom-lesson-one
# 暴露/actuator/prometheus,如果配置了* ,则可以不配置这一行
management.endpoints.web.exposure.include: prometheus
# 暴露的数据中添加application label
management.metrics.tags.application: ${spring.application.name}

3 访问

可以看到我们已经有了prometheus的数据
http://127.0.0.1:8888/actuator/prometheus

整合Grafana

我们将上面准备好的应用部署到服务上然后对prometheus做如下配置:

yml 复制代码
- job_name: 'jvm_demo'
  metrics_path: '/actuator/prometheus'
  static_configs:
  - targets: ['10.0.4.5:8888']

然后访问地址:http://ip:9090/targets 看到up状态说明我们刚刚jvm这个节点可以用了。

然后我们新建一个数据源:

填prometheus地址:ip:9090

然后我们加载一个模板:

12856


下面你就可以得到一个有点炫酷的界面,来实时的监控服务堆内存的情况。

相关推荐
未若君雅裁12 分钟前
JVM 垃圾回收算法与分代回收机制
java·jvm·算法
智者知已应修善业18 分钟前
【51单片机初始化D5-D8亮,每按键按下D1到D4全亮,再按下恢复,如此循环】2024-3-26
c++·经验分享·笔记·算法·51单片机
skywalk816320 分钟前
记录段言的开发过程
开发语言·学习·编程
知识分享小能手20 分钟前
Hadoop学习教程,从入门到精通, MapReduce分布式计算框架 — 完整知识点与代码案例(4)
hadoop·学习·mapreduce
未若君雅裁28 分钟前
JVM 垃圾回收器全景与G1深度解析
java·开发语言·jvm
YM52e1 小时前
鸿蒙HarmonyOS ArkTS 实战:教师座椅出入记录 APP 从零到一
学习·华为·harmonyos·鸿蒙系统
juesdo1 小时前
青岑CTF之 EZPHP系列
笔记·web安全·php
踏着七彩祥云的小丑1 小时前
嵌入式测试第 32 天:升级测试:固件OTA升级、断点续传、回滚测试
单片机·嵌入式硬件·学习
小陈phd1 小时前
Text2SQL智能体学习笔记(二)——NL2SQL落地的隐形基石:元数据库
数据库·笔记·学习
hereitis贝壳1 小时前
GC.lsp:AutoCAD 中实用的轻量化公差标注插件
jvm·里氏替换原则