spring:
profiles:
active: admin
server:
port: 8888
# application-admin.yml
spring:
application:
name: admin
服务端AdminServer
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-starter-server</artifactId>
<version>2.4.2</version>
</dependency>
启动AdminServer,等等客户端注册,然后根据客户端暴露的端点就可以监控客户端
@SpringBootApplication
// SpringBootAdmin它是一个单独的WEB项目
// 它可以监控各个微服务暴露的一些项目信息的端点
// 获取各个服务的信息,然后显示到自己的监控页面上
@EnableAdminServer
public class SpringBootAdminServer {
public static void main(String[] args) {
SpringApplication.run(SpringBootAdminServer.class, args);
}
}
客户端AdminClient
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-starter-client</artifactId>
<version>2.4.2</version>
</dependency>
客户端配置信息,暴露端点的看"SpringBoot监控指标actuator的使用"这篇文章
spring:
application:
name: monitor
# 开启springboot admin监控
# admin server每隔一段时间就会获取当前服务的状态信息
# 通过http://localhost:8888(AdminServer启动端口)访问AdminServer服务
boot:
admin:
client:
# 将当前项目暴露的端点信息发送到AdminServer中
# 配置的是AdminServer的地址
url: http://localhost:8888
# instance:
# 允许通过ip注册
# prefer-ip: true
# 与监控相关的配置key都是以management开头
# 每一个端点就表示一个单独模块的功能,这些监控端点官网都有
# https://docs.spring.io/spring-boot/docs/2.7.18/reference/html/actuator.html#actuator.endpoints
# 端点的访问格式: http://localhost:8080/actuator/端点名称/端点子属性
# 显示所有暴露的端点: http://localhost:8080/actuator/
# 常用的端点
# 1. beans: spring中完整的bean列表
# 2. conditions: 自动装配的条件信息,匹配成功和不匹配的原因
# 3. configprops: 显示所有的@ConfigProperties
# 4. env: 暴露spring的环境对象
# 5. health: 显示应用程序运行状态(重要)
# 6. info: 应用程序信息
# 7. loggers: 显示和修改应用程序中的日志配置
# 8. metrics: 应用程序的指标信息(重要)
# 9. mappings: 显示所有RequestMapping列表
# 10. scheduledtasks: 显示应用程序中的定时任务
# 11. sessions: 允许从Spring Session支持的会话存储中检索和删除会话
# 12. shutdown: 使应用程序正常关闭,默认禁用
management:
endpoints:
# 默认开启所有端点,一般不会这样做,不太安全
enabled-by-default: true
# 以web的方式暴露端点信息,也就是http
web:
exposure:
include: '*'
# 方法端点的基本路径
base-path: /actuator
# 以jmx的方式暴露端点信息
# jmx:
# exposure:
# include: '*'
# 单独启用端点
endpoint:
# 这个健康信息我们可以进行自定义,自定义某个组件的健康信息,实现HealthIndicator接口
health:
enabled: true
# 显示健康的详细信息
show-details: always
# 这个应用信息我们可以进行自定义,实现InfoContributor接口
info:
enabled: true
# 开启info端点包含info开头的属性变量
info:
env:
enabled: true
# 通过info定义的配置属性,可以被监控的info端点获取到
info:
app-name: luck-springboot
version: 1.0
# 获取配置的规则@ 配置名称 @
maven: "@project.parent.version@"
客户端启动就是一个正常的SpringBoot项目就OK,只需要引入依赖配置就行