使用Actuator通过HTTP监控Spring Boot应用(附源码)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 使用Actuator通过HTTP监控Spring Boot应用(附源码)

Spring Boot提供了Actuator功能,完成运行时的应用监控和管理功能。可以通过HTTP,JMX(Java管理扩展)以及SSH(远程脚本)来进行Spring Boot的应用监控和管理功能。

通过HTTP使用Actuator的监控和管理功能,那么要在pom.xml文件中引入以下依赖

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

一、端点的分类与测试

Spring  Boot提供了许多监控和管理功能的端点。根据端点的作用,可以将Spring Boot提供 的原生端点分为三大类。应用配置端点、度量指标端点、操作控制端点

1:端点的开启与暴露

新建一个Spring Boot Web应用 运行主程序 然后通过访问http://localhost:8080/acutator来查看默认暴露的端点

发现Spring Boot默认暴露了health和info两个端点

在配置文件application.properties中添加以下代码可以查看所有暴露的端点

management.endpoints.web.exposure.include=*

二、应用配置端点的测试

1:conditions

用于获取应用的自动化配置报告,其中包括所有自动化配置的候选项,同时还列出了每个候选项自动化配置的各个先决条件是否满足

访问http://localhost:8080/acutator/conditions即可测试

2:beans

该端点用来获取应用上下文中创建的所有Bean,启动并暴露该端点后。可通过http://localhost:8080/beans访问

3:configprops

该端点用来获取应用中配置的属性信息报告,prefix属性代表属性的配置前缀,properties代表各个属性的名称和值 通过http://localhost:8080/acutator/configprops测试访问

4:env

该端点用于获取应用所有可用的环境属性报告。

通过http://localhost:8080/acutato/env访问

5:mappings

该端点用来返回所有Spring MVC的控制器映射关系报告 可通过

http://localhost:8080/acutator/mappings访问

6:info

该端点用来返回一些自定义的信息,在默认情况下,该端点只会返回一个空的json内容

通过http://localhost:8080/acutator/info测试访问

三、度量指标端点的测试

通过度量指标端点可获取应用程序运行过程中用于监控的度量指标

1:metrics

该端点用来返回当前应用的各类重要度量指标

通过http://localhost:8080/acutator/metrics访问

2:health

该端点哦你过来获取应用的各类健康指标信息。通过

http://localhost:8080/acutator/health访问 up表示健康 down表示异常

3:threaddump

该端点用来暴露程序运行中的线程信息。 通过

http://localhost:8080/acutator/threaddump测试访问

4:httptrace

该端点用来返回基本的HTTP跟踪信息。可通过

http://localhost:8080/acutator/httptrace访问 保留最近的100条请求信息

5:scheduledtasks

该端点统计应用程序中调度的任务 可通过

http://localhost:8080/acutator/scheduledtasks访问测试

四、操作控制端点的测试

操作控制类端点拥有更强大的控制能力,如果使用它们,需要通过属性来配置开启,在原生端点中,只提供了一个用来关闭应用的端点:shutdown 可以通过如下配置开启它

management.endpoint.shutdown.enabled=true

五、自定义端点

当Spring Boot提供的端点不能满足我们的需求时,就需要自定义 一个端点对应用进行监控

Spring Boot提供了注解@Endpoint定义一个端点类,并在端点类的方法上使用@ReadOperation注解来显示监控信息,使用@WriteOperation来动态更新监控信息

下面通过实战讲解如何自定义一个端点,并且显示数据源相关信息

1:创建Spring Boot Web应用

2:修改pom.xml

<?xml version="1.0" encoding="UTF-8"?>
-<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0">
<modelVersion>4.0.0</modelVersion>
-<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.8.RELEASE</version>
<relativePath/>
<!-- lookup parent from repository -->
</parent>
<groupId>com.ch</groupId>
<artifactId>ch10_2</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>ch10_2</name>
<description>Demo project for Spring Boot</description>
-<properties>
<java.version>11</java.version>
</properties>
-<dependencies>
-<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
-<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
-<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.45</version>
</dependency>
-<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
-<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
-<build>
-<plugins>
-<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>

3:配置数据源

修改application.properties文件

###
##数据源信息配置
###
#数据库地址
spring.datasource.url=jdbc:mysql://localhost:3306/springbootjpa?characterEncoding=utf8
#数据库用户名
spring.datasource.username=root
#数据库密码
spring.datasource.password=root
#数据库驱动
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
#输出的JSON字符串格式更美观
spring.jackson.serialization.indent-output=true
#暴露所有端点,当然包括data-source,我们也可以只暴露data-source端点
management.endpoints.web.exposure.include=*
#将详细健康信息显示给所有用户
management.endpoint.health.show-details=always

4:自定义端点

package com.ch.ch10_2.endPoint;
import java.util.HashMap;
import java.util.Map;
import org.springframework.boot.actuate.endpoint.annotation.Endpoint;
import org.springframework.boot.actuate.endpoint.annotation.ReadOperation;
import org.springframework.boot.actuate.endpoint.annotation.WriteOperation;
import org.springframework.stereotype.Component;
import com.zaxxer.hikari.HikariConfigMXBean;
import com.zaxxer.hikari.HikariDataSource;
import com.zaxxer.hikari.HikariPoolMXBean;
//注册为端点,id不能使用驼峰法(dataSource),需要以-分割
@Endpoint(id = "data-source")
@Component
public class DataSourceEndpoint {
  //HikariDataSource提供多个监控信息
  HikariDataSource ds;
    public DataSourceEndpoint(HikariDataSource ds) {
      this.ds = ds;
    }
    @ReadOperation
    public Map<String, Object> info() {
      Map<String, Object> map = new HashMap<String, Object>();
      //连接池配置
      HikariConfigMXBean configBean = ds.getHikariConfigMXBean();
      map.put("max", configBean.getMaximumPoolSize());
      //连接池运行状态
      HikariPoolMXBean mxBean = ds.getHikariPoolMXBean();
      map.put("active", mxBean.getActiveConnections());
      map.put("idle", mxBean.getIdleConnections());
      //连接池无连接时,等待获取连接的线程个数
      map.put("wait", mxBean.getThreadsAwaitingConnection());
        return map;
    }
    @WriteOperation
    public void setMax(int max) {
      ds.getHikariConfigMXBean().setMaximumPoolSize(max);
    }
}

5:暴露端点

在application.properties中添加以下代码

management.endpoints.web.exposure.include=*

6:测试端点

运行主类 然后访问http://localhost:8080/actuator/date-source即可

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7天前
|
Web App开发 编解码 Java
B/S基层卫生健康云HIS医院管理系统源码 SaaS模式 、Springboot框架
基层卫生健康云HIS系统采用云端SaaS服务的方式提供,使用用户通过浏览器即能访问,无需关注系统的部署、维护、升级等问题,系统充分考虑了模板化、配置化、智能化、扩展化等设计方法,覆盖了基层医疗机构的主要工作流程,能够与监管系统有序对接,并能满足未来系统扩展的需要。
33 4
|
25天前
|
缓存 前端开发 Java
【Java】仓库管理系统 SpringBoot+LayUI+DTree(源码)【独一无二】
【Java】仓库管理系统 SpringBoot+LayUI+DTree(源码)【独一无二】
|
30天前
|
安全 Java 数据安全/隐私保护
【深入浅出Spring原理及实战】「EL表达式开发系列」深入解析SpringEL表达式理论详解与实际应用
【深入浅出Spring原理及实战】「EL表达式开发系列」深入解析SpringEL表达式理论详解与实际应用
67 1
|
3天前
|
XML 人工智能 Java
Spring Bean名称生成规则(含源码解析、自定义Spring Bean名称方式)
Spring Bean名称生成规则(含源码解析、自定义Spring Bean名称方式)
|
9天前
|
人工智能 移动开发 前端开发
Springboot医院智慧导诊系统源码:精准推荐科室
医院智慧导诊系统是在医疗中使用的引导患者自助就诊挂号,在就诊的过程中有许多患者不知道需要挂什么号,要看什么病,通过智慧导诊系统,可输入自身疾病的症状表现,或选择身体部位,在经由智慧导诊系统多维度计算,精准推荐科室,引导患者挂号就诊,实现科学就诊,不用担心挂错号。
18 2
|
10天前
|
人工智能 前端开发 Java
Java语言开发的AI智慧导诊系统源码springboot+redis 3D互联网智导诊系统源码
智慧导诊解决盲目就诊问题,减轻分诊工作压力。降低挂错号比例,优化就诊流程,有效提高线上线下医疗机构接诊效率。可通过人体画像选择症状部位,了解对应病症信息和推荐就医科室。
151 10
|
10天前
|
Java 关系型数据库 MySQL
一套java+ spring boot与vue+ mysql技术开发的UWB高精度工厂人员定位全套系统源码有应用案例
UWB (ULTRA WIDE BAND, UWB) 技术是一种无线载波通讯技术,它不采用正弦载波,而是利用纳秒级的非正弦波窄脉冲传输数据,因此其所占的频谱范围很宽。一套UWB精确定位系统,最高定位精度可达10cm,具有高精度,高动态,高容量,低功耗的应用。
一套java+ spring boot与vue+ mysql技术开发的UWB高精度工厂人员定位全套系统源码有应用案例
|
11天前
|
存储 数据可视化 安全
Java全套智慧校园系统源码springboot+elmentui +Quartz可视化校园管理平台系统源码 建设智慧校园的5大关键技术
智慧校园指的是以物联网为基础的智慧化的校园工作、学习和生活一体化环境,这个一体化环境以各种应用服务系统为载体,将教学、科研、管理和校园生活进行充分融合。无处不在的网络学习、融合创新的网络科研、透明高效的校务治理、丰富多彩的校园文化、方便周到的校园生活。简而言之,“要做一个安全、稳定、环保、节能的校园。
37 6
|
13天前
|
消息中间件 运维 供应链
springboot区域云HIS医院信息综合管理平台源码
云HIS系统分为两个大的系统,一个是基层卫生健康云综合管理系统,另一个是基层卫生健康云业务系统。基层卫生健康云综合管理系统由运营商、开发商和监管机构使用,用来进行运营管理、运维管理和综合监管。基层卫生健康云业务系统由基层医院使用,用来支撑医院各类业务运转。
21 2
|
25天前
|
存储 安全 Java
Spring Security应用讲解(Java案列演示)
Spring Security应用讲解(Java案列演示)