SpringBoot Admin 详解

news2025/1/18 21:17:53

SpringBoot Admin 详解

  • 一、Actuator 详解
    • 1.Actuator原生端点
      • 1.1 监控检查端点:health
      • 1.2 应用信息端点:info
      • 1.3 http调用记录端点:httptrace
      • 1.4 堆栈信息端点:heapdump
      • 1.5 线程信息端点:threaddump
      • 1.6 获取全量Bean的端点:beans
      • 1.7 条件自动配置端点:conditions
      • 1.8 配置属性端点:configprops
      • 1.9 追踪度量端点:metrics
      • 1.10 根据名称追踪度量端点:metrics/{name}
      • 1.11 获取全部环境端点:env
      • 1.12 根据名称获取环境属性端点:env/{name}
      • 1.13 审计事件端点:auditevents
      • 1.14 停止Actuator端点:shutdown
    • 2.使用Actuator
      • 2.1 引入依赖
      • 2.2 增加配置信息
      • 2.3 验证端点
      • 2.5 自定义根路径
  • 二、SpringBoot Admin 详解
    • 1.服务端搭建
      • 1.1 引入依赖
      • 1.2 启动类增加注解
      • 1.3 启动服务
    • 2.客户端搭建
      • 2.1 引入依赖
      • 2.2 增加application.yml配置
      • 2.3 启动客户端
  • 三、SpringBoot Admin功能展示
    • 1.功能介绍-细节
    • 2.功能介绍-环境
    • 3.功能介绍-类
    • 4.功能介绍-配置属性
    • 5.功能介绍-日志配置
    • 6.功能介绍-JVM
    • 7.功能介绍-映射

SpringBoot Admin是一个三方的监控和服务管理组件,常用于服务监控的检查,服务元信息获取,是一个轻量且简单的组件。他依赖于Actuator暴漏的接口完成大部分功能,Actuator是一个用于提供服务多种监控接口的组件。这里先总结Actuator的用法,再介绍SpringBoot Admin集成Actuator以后如何使用。

一、Actuator 详解

Actuator是一个可以快速集成在SpringBoot项目中的组件,他支持对单个项目暴露监控接口,同时还支持自定义的监控接口,方便我们进行自定义的一些信息监控,比如说health这个是用途最广范的接口,经常被用来做服务的健康检查,企业中有各种各样的监控组件,但无论使用何种监控组件都需要有一个接口对外提供健康信息展示,那health就可以做这个事情。

1.Actuator原生端点

所谓原生端点(Endpoint)就是指Actuator自带的监控接口,这些接口是最常用、最普遍的监控类接口,适用于大多数场景,一般这些场景是完全够用的了,除非有特殊场景,否则是无需自己定义端点信息的。下面根据这些监控接口的常用频率来由高到底进行说明。

1.1 监控检查端点:health

接口地址:/health
请求方式:GET
端点作用:验证服务是否健康,是否在线的接口,这个也是最常用的接口,一般对服务的监控监控都是使用该接口,SpringBoot项目基本都会使用该接口做健康监控。

1.2 应用信息端点:info

接口地址:/info
请求方式:GET
端点作用:获取自定义的info信息,使用时需要在配置文件增加info开头的配置信息,比如如下:

1.3 http调用记录端点:httptrace

接口地址:/httptrace
请求方式:GET
端点作用:默认显示最近100次的http调用记录,包含请求和响应

1.4 堆栈信息端点:heapdump

接口地址:/heapdump
请求方式:GET
端点地址:可以返回一份jvm的堆信息,这个功能和jvm参数的堆转存储快照类似

1.5 线程信息端点:threaddump

接口地址:/threaddump
请求方式:GET
端点作用:获取线程活动的信息

1.6 获取全量Bean的端点:beans

接口地址:/beans
请求方式:GET
端点作用:获取服务中全部的Bean的信息

1.7 条件自动配置端点:conditions

接口地址:/conditions
请求方式:GET
端点作用:用于显示系统中使用条件进行装配的信息的情况,常见的有ConditionalOnProperty等,只有满足某些条件才会进行操作,此端点用于显示此类的条件满足情况。

1.8 配置属性端点:configprops

接口地址:/configprops
请求方式:GET
端点作用:描述的是属性被Bean加载的信息

1.9 追踪度量端点:metrics

接口地址:/metrics
请求方式:GET
端点作用:内存、http等信息的追踪展示

1.10 根据名称追踪度量端点:metrics/{name}

接口地址:/metrics/{name}
请求方式:GET
端点作用:指定名称的展示

1.11 获取全部环境端点:env

接口地址:/env
请求方式:GET
端点作用:获取服务的全部环境信息

1.12 根据名称获取环境属性端点:env/{name}

接口地址:/env/{name}
请求方式:GET
端点作用:指定名称获取对应环境属性的值

1.13 审计事件端点:auditevents

接口地址:/auditevents
请求方式:GET
端点作用:显示应用的审计事件,比如认证失败等

1.14 停止Actuator端点:shutdown

接口地址:/shutdown
请求方式:POST
端点作用:用以关闭Actuator所在的应用服务,注意只有这个是POST,使用他可以不用进入服务器就实现应用的关闭,比如某个服务异常了,想要将这个服务从集群中剔除出去,就可以使用这个功能。

2.使用Actuator

这里使用一个SpringBoot项目进行测试Actuator的提供的这些接口。注意这个项目得是web项目。

2.1 引入依赖

这里需要至少引入web和Actuator的依赖


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

<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-web</artifactId>
     <version>2.6.11</version>
 </dependency>

2.2 增加配置信息

如果不增加配置信息,上面的这些监控接口就只有个别的开启了,大部分是不可用的,比如health是开启的但也只展示在线信息,所以我们需要开启其他端点。下面的配置信息都有详细的注解,这里不做多余的解释了,解释详见配置上的注释,正常生产使用这些配置也完全够用了:

server:
  port: 8093

#  配置应用名称, 方便监控使用
spring:
  application:
    name: test-actuator
    version: 1.0.0


# 暴露监控端点
management:
  endpoints:
    web:
      exposure:
        # 配置需要暴露出去的端点,一般直接*暴露全部就行
        include: "*"
  endpoint:
    health:
      # health 默认只展示 是否在线,增加该配置后会展示更多信息
      show-details: ALWAYS
    shutdown:
      # 启用关闭应用的功能,不启用则无法关闭应用
      enabled: true
  info:
    env:
      # 开启info端点的配置支持,不开启info将无信息返回,即使配置了info也无信息
      enabled: true
# 自定义info端点信息,info端点获取的就是这里的信息
info:
  title: ${spring.application.name}服务
  version: ${spring.application.name}-${spring.application.version}
  description: ${spring.application.name}服务监控

2.3 验证端点

上面配置增加完以后就可以启动服务了,这里基本不会有任何意外,然后开始验证接口。

  • 验证health端点
    注意这里actuator是固定前缀,支持更改(生产如果处于安全考虑可以更改):

    http://localhost:8093/actuator/health
    

    health端点的信息如下,这里包含了在线状态服务器的ping状态,服务器的磁盘信息等。在这里插入图片描述

  • 验证info端点
    info端点的信息是自定义信息,这里验证是否返回的是我们自定义的信息

    http://localhost:8093/actuator/info
    

    可以看到返回的正式我们自定义的信息,这里信息可以随便指定,title、version等名称都是随便指定的。
    在这里插入图片描述

  • 验证beans端点
    这个是获取全量bean信息的端点

    http://localhost:8093/actuator/beans
    

    结果如下图,也没啥问题
    在这里插入图片描述

  • 验证shutdown端点
    这个接口需要使用POST方式进行调用

    http://localhost:8093/actuator/shutdown
    

    然后借助postman进行调用测试,结果如下:
    在这里插入图片描述
    然后观察应用程序,发现确实已经被关闭了:
    在这里插入图片描述

  • 验证jvm端快照端点
    这个可以用来观察生产实时的堆信息,还是有一些作用的。

    http://localhost:8093/actuator/heapdump
    

    请求后会直接下载一份堆信息,需要我们使用对应工具才可以打开,网上一堆这种在线工具,下面是执行截图:
    在这里插入图片描述
    可以随便找个在线工具打开看看,这里笔者用的是这个:https://heaphero.io/heap-index.jsp#header
    分析结果如下,这里不做jvm知识的拓展了,从下图可以看到已经正常分析出了堆的信息了,说明我们拿到的dump文件时可用的:
    在这里插入图片描述
    端点验证就不一一验证了。

2.5 自定义根路径

上面也提到过,Actuator是支持自定义根路径的,如果使用根路径会有一些安全隐患,比如别人通过抓包知道了你的接口地址,就可以使用Actuator的接口使用DOS进行攻击你的系统,这是有安全隐患的,解决这个办法有的是去集成认证,有的是更改默认地址,默认地址更改后就很难猜出来真正的端点地址了。所以这里建议生产更改默认的接口地址,如下:

# 暴露监控端点
management:
  endpoints:
    web:
      # 这是监控的默认根路径,支持自定义
      base-path: /observe

重启服务进行验证,如下,可见地址更改生效:
在这里插入图片描述

二、SpringBoot Admin 详解

SpringBoot Admin是一个在github上开元的社区项目,通过使用Actuator暴漏的端点来是实现项目的可视化监控和管理。SpringBoot Admin是一个简单易用的小组件,易上手,可以作为中小公司健康监控系统的使用是没有太大问题的。
SpringBoot Admin是一个BS架构,分为客户端和服务端,这里分别就进行介绍。

1.服务端搭建

服务端搭建也比较简单,只需要少量的配置就可以运行,首先我们需要导入所需服务端的依赖

1.1 引入依赖

这里需要引入web和admin-server两个依赖,admin监控的肯定是web服务,所以这里引入web依赖。

<!-- 版本保持与springboot统一即可 -->
<dependency>
    <groupId>de.codecentric</groupId>
    <artifactId>spring-boot-admin-starter-server</artifactId>
    <version>2.6.11</version>
</dependency>

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <version>2.6.11</version>
</dependency>

1.2 启动类增加注解

这个也比较简单,直接启动类上增加一个注解即可,用以表示admin的服务端。

@EnableAdminServer

如下:
在这里插入图片描述

1.3 启动服务

只需要简单的两步导入依赖和增加注解即可开启一个服务端,服务启动基本不会有任何异常,服务启动完成以后,然后打开如下地址:

# applications 是默认地址
http://localhost:8094/applications

然后展示如下,此时没有客户端,所有目前这里没有任何信息,信息的展示需要等到客户端同样启动以后才会有展示:
在这里插入图片描述

2.客户端搭建

客户端搭建也很简单,只需要引入web依赖和admin的客户端依赖就行,注意客户端不需要重复引入Actuator的依赖,因为Admin的客户端已经默认引入了这个依赖。

2.1 引入依赖

<!-- 客户端依赖版本保持和服务端一致 -->
<dependency>
    <groupId>de.codecentric</groupId>
    <artifactId>spring-boot-admin-starter-client</artifactId>
    <version>2.6.11</version>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <version>2.6.11</version>
</dependency>

2.2 增加application.yml配置

客户端因为默认是集成了Actuator的,所以我们上面使用的Actuator的配置依然是可用的,只需要在原有的Actuator的配置基础上增加服务端地址的信息指定即可,客户端全部配置信息如下:

server:
  port: 8093

#  配置应用名称, 方便监控使用
spring:
  application:
    name: test-actuator
    version: 1.0.0
  boot:
    admin:
      client:
        # 指定admin-server的地址
        url:  http://localhost:8094


# 暴露监控端点
management:
  endpoints:
    web:
      exposure:
        # 配置需要暴露出去的端点,一般直接*暴露全部就行
        include: "*"
      # 这是监控的默认根路径,支持自定义
      base-path: /observe
  endpoint:
    health:
      # health 默认只展示 是否在线,增加该配置后会展示更多信息
      show-details: ALWAYS
    shutdown:
      # 启用关闭应用的功能,不启用则无法关闭应用
      enabled: true
  info:
    env:
      # 开启info端点的配置支持,即使配置了info也无信息
      enabled: true
# 自定以info端点信息,info端点获取的就是这里的信息
info:
  title: ${spring.application.name}服务
  version: ${spring.application.name}-${spring.application.version}
  description: ${spring.application.name}服务监控

2.3 启动客户端

添加完配置以后直接启动客户端服务就行了,客户端服务启动完成后就可以导服务端的页面中查看信息了,服务端地址:http://localhost:8094/applications
信息展示如下:
在这里插入图片描述
到这里客户端和服务端的搭建就全部完成了,以下介绍下admin的使用。

三、SpringBoot Admin功能展示

SpringBoot Admin其实就是将Actuator暴露的端点进行了可视化,这里大部分的接口都是Actuator提供的。
在admin-server的首页点击服务名,如下
在这里插入图片描述
然后会弹出如下的服务信息,这里继续点击服务名,即可进入到当前服务的监控页面了
在这里插入图片描述
点击后进入到下面的页面,几乎主要的功能都在这里了:
在这里插入图片描述
或者也可以从如下位置直接点击进入到上图的页面:
在这里插入图片描述

1.功能介绍-细节

细节这块的信息,仔细一看就会比较熟悉了,基础展示如下:
信息:展示的是info端点的信息。
监控:展示的就是health的信息
元数据:项目的启动时间
进程:项目的进程id使用的cpu等信息
线程:线程的总数与当前系统使用的线程数
垃圾回收:jvm垃圾回收的次数与耗时
内存heap:jvm堆使用信息
non heap:jvm栈的使用信息
在这里插入图片描述
在这里插入图片描述

2.功能介绍-环境

这里展示的是项目加载和使用的各种环境变量信息的key和value,使用的就是env端点,没啥特别需要说的
在这里插入图片描述

3.功能介绍-类

这里展示的是spring容器加载的类信息,其实就是beans端点,用来查看所有的加载的bean信息。
在这里插入图片描述

4.功能介绍-配置属性

这里其实就configprops端点在这里插入图片描述

5.功能介绍-日志配置

这里可以动态调整系统各个目录的日志级别,这个还是有用的,调整后实时生效

在这里插入图片描述

6.功能介绍-JVM

这里是heapdump和threaddump的信息,在这里可以看到线程和jvm堆的信息
在这里插入图片描述

7.功能介绍-映射

这个是mappings端点,用于展示接口和类之间的关系
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1470082.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

找游戏 - 华为OD统一考试(C卷)

OD统一考试&#xff08;C卷&#xff09; 分值&#xff1a; 200分 题解&#xff1a; Java / Python / C 题目描述 小扇和小船今天又玩起来了数字游戏&#xff0c; 小船给小扇一个正整数 n&#xff08;1 ≤ n ≤ 1e9&#xff09;&#xff0c;小扇需要找到一个比 n 大的数字 m&a…

PMP项目管理考试要注意些什么?

PMP考试和PMP备考过程中应该注意哪些问题&#xff1f; PMP备考完成后就要迎接实战考试了&#xff0c;考试前千万不要有多余的想法&#xff0c;顺其自然就行了&#xff0c;我想大家各种紧张、各种忧虑的原因大抵是因为考试成本考&#xff0c;担心考不过&#xff0c;其实只要你在…

【并发】CAS原子操作

1. 定义 CAS是Compare And Swap的缩写&#xff0c;直译就是比较并交换。CAS是现代CPU广泛支持的一种对内存中的共享数据进行操作的一种特殊指令&#xff0c;这个指令会对内存中的共享数据做原子的读写操作。其作用是让CPU比较内存中某个值是否和预期的值相同&#xff0c;如果相…

Linux——缓冲区封装系统文件操作

&#x1f4d8;北尘_&#xff1a;个人主页 &#x1f30e;个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上&#xff0c;不忘来时的初心 文章目录 一、FILE二、封装系统接口实现文件操作1、text.c2、mystdio.c3、mystdio.h 一、FILE 因为IO相…

基于粒子群算法优化BP神经网络的黄酮含量预测,基于pso-bp的黄酮水平预测,基于bp神经网络的黄酮预测

目录 摘要 BP神经网络的原理 BP神经网络的定义 BP神经网络的基本结构 BP神经网络的神经元 BP神经网络的激活函数, BP神经网络的传递函数 粒子群算法的原理及步骤 基于粒子群算法优化BP神经网络的黄酮含量预测,基于pso-bp的黄酮水平预测,基于bp神经网络的黄酮预测 matlab代码…

【线程池项目(三)】线程池CACHED模式的实现

在上一篇【线程池项目&#xff08;二&#xff09;】线程池FIXED模式的实现 中我们了解到到线程池fixed模式的大致实现原理&#xff0c;但对于一个比较完整的项目来说&#xff0c;我们还需要考虑到可能会发生的各种情况&#xff0c;比如用户提交的任务数可能在某一时刻急剧增加&…

5.2 Ajax 数据爬取实战

目录 1. 实战内容 2、Ajax 分析 3、爬取内容 4、存入MySQL 数据库 4.1 创建相关表 4.2 数据插入表中 5、总代码与结果 1. 实战内容 爬取Scrape | Movie的所有电影详情页的电影名、类别、时长、上映地及时间、简介、评分&#xff0c;并将这些内容存入MySQL数据库中。 2、…

在springboot中调用openai Api并实现流式响应

之前在《在springboot项目中调用openai API及我遇到的问题》这篇博客中&#xff0c;我实现了在springboot中调用openai接口&#xff0c;但是在这里的返回的信息是一次性全部返回的&#xff0c;如果返回的文字比较多&#xff0c;我们可能需要等很久。 所以需要考虑将请求接口响应…

LeetCode--代码详解 235.二叉搜索树得最近公共祖先

235.二叉搜索树得最近公共祖先 题目 给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个结点 p、q&#xff0c;最近公共祖先表示为一个结点 x&#xff0c;满足 x 是 p、q 的祖先且 x 的深度尽可…

【架构】面向人工智能 (AI) 的硬件的可靠性(2021)

由于激进的技术扩展&#xff0c;现代系统越来越容易受到可靠性威胁的影响&#xff0c;例如软错误、老化和工艺变化。这些威胁在硬件级别表现为位翻转&#xff0c;并且根据位置&#xff0c;可能会损坏输出&#xff0c;从而导致不准确或潜在的灾难性结果。 传统的缓解技术基于冗…

计算机网络Day03--物理层

信道复用技术 频分复用 时分复用 统计时分复用 频分复用&#xff08;FDM&#xff09; 最基本 将整个宽带分为多份&#xff0c;用户在分配到一定的频带后&#xff0c;在通信过程中自始至终都使用这个频带 所有的用户在同一时间占用不同的带宽资源&#xff0c;以并行的方式工…

一文带你彻底搞懂 Python 编程进阶之闭包

什么是闭包&#xff1a;在函数嵌套的情况下&#xff0c;内部的函数使用外部函数中的变量&#xff0c;并且外部函数返回了内部函数&#xff0c;我们将这个内部函数称之为闭包。 闭包是实现装饰器的基础&#xff0c;通过装饰器可以在不修改原函数代码的情况下增强其功能。 在Py…

JDK10新特性:探索Java10的编程新境界

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

nodejs+vue+ElementUi废品废弃资源回收系统

系统主要是以后台管理员管理为主。管理员需要先登录系统然后才可以使用本系统&#xff0c;管理员可以对系统用户管理、用户信息管理、回收站点管理、站点分类管理、站点分类管理、留言板管理、系统管理进行添加、查询、修改、删除&#xff0c;以保障废弃资源回收系统系统的正常…

异步框架Celery在Django中的运用

参考博客&#xff1a;https://www.cnblogs.com/pyedu/p/12461819.html 参考视频&#xff1a;01 celery的工作机制_哔哩哔哩_bilibili 定义&#xff1a;简单灵活、处理大量消息的分布式系统&#xff0c;专注于实时处理异步队列&#xff0c;支持任务调度 主要架构&#xff1a; …

YOLOv7基础 | 第2种方式:简化网络结构之yolov7.yaml(由104层简化为30层)

前言:Hello大家好,我是小哥谈。通过下载YOLOv7源码可知,原始的yolov7.yaml文件是拆开写的,比较混乱,也不好理解,并且为后续改进增添了很多困难。基于此种情况,笔者就给大家介绍一种将yolov7.yaml文件简化的方法,将104层简化为30层,并且参数量和计算量和原来是一致的,…

RK3568平台开发系列讲解(Linux系统篇)字符设备驱动:分配和注册字符设备

🚀返回专栏总目录 文章目录 一、分配和注册字符设备二、file_operations沉淀、分享、成长,让自己和他人都能有所收获!😄 一、分配和注册字符设备 字符设备在内核中表示为struct cdev的实例。在编写字符设备驱动程序时,目标是最终创建并注册与struct file_operations关联…

线程池的常用实现及执行流程

线程池 线程池线程池接口线程池参数线程池分类动态数目线程池固定数目线程池单例线程池任务调度线程池 线程池的执行流程 线程池 线程池接口 线程池参数 1、corePoolSize&#xff1a;核心线程数&#xff0c;线程池中最少线程&#xff0c;核心线程不会被回收。 2、maximumPoo…

Edting While Playing 瓦片地图编辑器开发整合导入自定义贴图 DEVC++ VS2022都可复制粘贴运行

接 多种类型图片模块读取-CSDN博客 与 Editing While Playing 使用 Easyx 开发的 RPG 地图编辑器 tilemap eaitor-CSDN博客 整合实现平面贴图纹理自定义 操作同上 导入步骤&#xff1a; 先运行程序&#xff0c;然后关闭&#xff0c;同目录下有四个文件夹&#xff0c; 把…

家政小程序有哪些功能 怎么制作

随着人们生活节奏的加快&#xff0c;家政服务变得越来越受到人们的青睐。为了提升家政服务的便捷性和高效性&#xff0c;家政小程序成为了越来越受欢迎的选择。下面具体介绍家政小程序有哪些功能&#xff0c;如何制作。 1. 展示家政服务 在小程序中&#xff0c;上传所有的家政…