当前位置:   article > 正文

SpringBoot Actuator和Spring boot Admin工具

SpringBoot Actuator和Spring boot Admin工具

目录

一、Spring Boot Actuator

1、简介

2、访问方式

3、端点

4、SpringBoot项目引入actuator

端点

①health

②beans

③configprops

④env

⑤loggers

⑥heapdump

⑦threaddump

⑧metrics

⑨scheduledtasks

⑩mappings

⑪shutdown

定制端点

一、定制health端点

二、自定义info端点

三、自定义metrics端点

四、自定义Endpoint

二、Spring Boot Admin

1、简介

2、搭建SpringBootAdmin

①、搭建服务端

②、搭建客户端

③、安全防护

④、邮件通知


一、Spring Boot Actuator

1、简介

官方介绍,为生产环境准备的特性。可以用来监控和管理发布到生产环境下的应用。比如,应用的健康状态、日志信息、内存占用、线程信息、Bean加载信息等等。

官网地址:

Spring Boot Actuator: Production-ready Featuresicon-default.png?t=N7T8https://docs.spring.io/spring-boot/docs/2.5.6/reference/html/actuator.html

2、访问方式

  • http
  • JMX

3、端点

端点就是SpringBoot Actuator对外暴露的一系列接口,actuator服务端可以通过这些接口获得对应的信息,比如日志、内存、线程等等。

Spring Boot Actuator: Production-ready Featuresicon-default.png?t=N7T8https://docs.spring.io/spring-boot/docs/2.5.6/reference/html/actuator.html#actuator.endpoints端点有actuator提供的原生的,也可以用户自定义端点。

原生端点是在应用程序里提供众多 Web 接口,通过它们了解应用程序运行时的内部状况。原生端点可以分成三类:

  • 应用配置类:可以查看应用在运行期的静态信息:例如自动配置信息、加载的 springbean 信息、yml 文件配置信息、环境信息、请求映射信息;
  • 度量指标类:主要是运行期的动态信息,例如堆栈、请求连、一些健康指标、metrics 信息等;
  • 操作控制类:主要是指 shutdown,用户可以发送一个请求将应用的监控功能关闭。

原生自带的端点有以下这些:也可以参考官网说明,只不过官网是英文。

每一个端点是可以设置启动或禁用的,Spring Boot 2.x版本默认是只启用了health 和 info两个端点,其他默认是关闭的。

4、SpringBoot项目引入actuator

创建SpringBoot项目,引入actuator依赖

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-actuator</artifactId>
  4. </dependency>

启动SpringBoot项目,访问 localhost:8080/actuator ,只要项目引入actuator依赖,就可以访问默认的health和info端点。

如果想开启所有的端点,将配置为 '*' 即可。如果配置多个用 , 分割

  1. management.endpoints.web.exposure.include=*
  2. management.endpoints.web.exposure.exclude=env,beans

端点

①health

health端点是显示服务或应用健康状态的接口,默认只显示状态,不显示详情,health有三种状态配置never、when-authorized、always,默认是never。

官网描述:Spring Boot Actuator: Production-ready Features

可以配置成always,则会显示状态详情,配置属性是management.endpoint.health.show-details,效
果如下:status是总的状态,其中有一个子节点的状态变为down的话,总的status也会变为down。

②beans

beans端点是注册进容器中的对象实例

③configprops

配置属性的信息

④env

配置的环境相关的变量属性

⑤loggers

各个包下的类对应的日志级别及其对应的信息展示。级别是可调的。调日志级别需要发送post请求,网页是无法发送的。

如果要远程查看日志信息,则需要将日志存储在文件中。配置属性logging.file.name,配置完以后会多一个端点 /logfile,存储日志信息。

⑥heapdump

容器运行时的jvm信息,比如堆栈占用信息等等,可以结合jdk自带的java VisualVM来分析。

⑦threaddump

线程的一些信息

⑧metrics

各个指标、http请求数,jdbc连接数,gc次数,cpu使用情况等等。

⑨scheduledtasks

任务调度

⑩mappings

映射信息

shutdown

优雅关闭

优雅关闭就是如果在关闭容器的时候,还有请求任务未处理完成,则等待这些任务处理完成并返回以后才会关闭容器。

容器需要先配置优雅关闭开启,server.shutdown = graceful

容器支持优雅关闭以后,就可以发送post请求到shutdown端点来优雅关闭容器。

定制端点

一、定制health端点

  1. @Component
  2. public class CustomHealthIndicator extends AbstractHealthIndicator {
  3. @Override
  4. protected void doHealthCheck(Health.Builder builder) throws Exception {
  5. boolean res = check();
  6. if (res) {
  7. builder.up();
  8. } else {
  9. builder.down();
  10. }
  11. }
  12. private boolean check() {
  13. return true;
  14. }
  15. }

实现抽象类,其中的doHealthCheck是检查端点是否健康的方法,在这里可以实现自定义。

访问 localhost:8080/actuator/health 效果如下:

二、自定义info端点

默认的info端点没有任何信息。

方式一:通过yml配置文件的方式实现

  1. info:
  2. app-name: test
  3. version: 3.0.0
  4. mavenversion: @project.artifactId@ # @@可以获取pom配置文件的属性值

效果:localhost:8080/actuator/info

方式二:编写代码的方式实现

  1. @Component
  2. public class CustomInfo implements InfoContributor {
  3. @Override
  4. public void contribute(Info.Builder builder) {
  5. builder.withDetail("k1", "v1")
  6. .withDetail("hello", "world")
  7. .withDetails(Collections.singletonMap("kkk", "vvv"));
  8. }
  9. }

效果:

配置文件和编写代码的方式可以同时使用,最终会汇集所有的信息。

三、自定义metrics端点

默认的metrics端点提供了jvm、数据库连接信息、cpu、进程相关的一些信息。

counter

计数器,一个简单的Meter,可以用来记录请求次数、支付订单次数等增长类的统计。

  1. //定制metrics counter指标
  2. Metrics.counter("count","tags").increment();

查看metrics端点,发现自定义的counter指标也出现了。

访问接口counter会增加,实现计数器的效果。

查看指标的具体数据,在http://localhost:8080/actuator/metrics/ 后面跟上对应的指标即可。

Timer

定时器指标,用来记录一些代码执行的时间计算。

Guage

一般用来记录有浮动值的数据,例如积压的消息,任务,集合、数组等等。

Summary

可以记录命中率的一些doble值。

四、自定义Endpoint

官网描述戳这里:Spring Boot Actuator: Production-ready Features

  1. @Component
  2. @Endpoint(id = "wjPoint")
  3. public class CustomPoint {
  4. Map<String,Object> map = new HashMap();
  5. {
  6. Map<String,String> m1 = new HashMap<>();
  7. m1.put("k1","v1");
  8. m1.put("k2","v2");
  9. Map<String,String> m2 = new HashMap<>();
  10. m2.put("k3","v3");
  11. m2.put("k4","v4");
  12. map.put("m1",m1);
  13. map.put("m2",m2);
  14. }
  15. @ReadOperation
  16. public Map getOperation(){
  17. return map;
  18. }
  19. }

二、Spring Boot Admin

1、简介

基于SpringBoot Actuator的可视化的监控平台,是一个vue程序。

官方地址:

GitHub - codecentric/spring-boot-admin: Admin UI for administration of spring boot applicationsAdmin UI for administration of spring boot applications - codecentric/spring-boot-adminicon-default.png?t=N7T8https://github.com/codecentric/spring-boot-admin文档说明地址:

Spring Boot Admin Reference Guideicon-default.png?t=N7T8https://docs.spring-boot-admin.com/2.5.1/#getting-started

2、搭建SpringBootAdmin

SpringBootAdmin分为服务端和客户端

服务端:即SpringBootAdmin这个监控平台

客户端:即被监控平台监控的后台应用或者容器服务

①、搭建服务端

第一步:创建SpringBoot服务作为admin服务端,服务端需要引入依赖(用到的SpringBoot的版本是2.5.6)

  1. <dependency>
  2. <groupId>de.codecentric</groupId>
  3. <artifactId>spring-boot-admin-starter-server</artifactId>
  4. <version>2.5.1</version>
  5. </dependency>

第二步:启动类加注解@EnableAdminServer

第三步,直接启动

浏览器可以访问,但是目前只有服务端,没有客户端的效果。

②、搭建客户端

第一步:创建SpringBoot应用程序作为客户端,引入依赖

  1. <dependency>
  2. <groupId>de.codecentric</groupId>
  3. <artifactId>spring-boot-admin-starter-client</artifactId>
  4. <version>2.5.1</version>
  5. </dependency>

第二步:yml中配置服务端的地址和要暴露的端点

  1. spring.boot.admin.client.url=http://localhost:8080
  2. management.endpoints.web.exposure.include=*

第三步:启动客户端

这时候服务端的监控页面就会出现一个刚刚启动的客户端实例,绿色就是正常的,如果显示红色或者灰色就需要查看客户端服务的健康状态了。

所有暴露的端点中的信息都可以在监控平台页面上面查看。

③、安全防护

SpringBootAdmin结合SpringSecurity做了登录的用户身份的校验,在进入监控页面之前需要先登录的功能。

Spring Boot Admin Reference Guideicon-default.png?t=N7T8https://docs.spring-boot-admin.com/2.5.1/#_securing_spring_boot_admin_server第一步:在服务端引入依赖

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-security</artifactId>
  4. </dependency>

第二步:配置SecureConfig配置类

官方有详细的说明,不懂Spring Security问题不大。

  1. @Configuration(proxyBeanMethods = false)
  2. public class SecuritySecureConfig extends WebSecurityConfigurerAdapter {
  3. private final AdminServerProperties adminServer;
  4. private final SecurityProperties security;
  5. public SecuritySecureConfig(AdminServerProperties adminServer, SecurityProperties security) {
  6. this.adminServer = adminServer;
  7. this.security = security;
  8. }
  9. @Override
  10. protected void configure(HttpSecurity http) throws Exception {
  11. SavedRequestAwareAuthenticationSuccessHandler successHandler = new SavedRequestAwareAuthenticationSuccessHandler();
  12. successHandler.setTargetUrlParameter("redirectTo");
  13. successHandler.setDefaultTargetUrl(this.adminServer.path("/"));
  14. http.authorizeRequests(
  15. (authorizeRequests) -> authorizeRequests.antMatchers(this.adminServer.path("/assets/**")).permitAll()
  16. .antMatchers(this.adminServer.path("/actuator/info")).permitAll()
  17. .antMatchers(this.adminServer.path("/actuator/health")).permitAll()
  18. .antMatchers(this.adminServer.path("/login")).permitAll().anyRequest().authenticated()
  19. ).formLogin(
  20. (formLogin) -> formLogin.loginPage(this.adminServer.path("/login")).successHandler(successHandler).and()
  21. ).logout((logout) -> logout.logoutUrl(this.adminServer.path("/logout"))).httpBasic(Customizer.withDefaults())
  22. .csrf((csrf) -> csrf.csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse())
  23. .ignoringRequestMatchers(
  24. new AntPathRequestMatcher(this.adminServer.path("/instances"),
  25. HttpMethod.POST.toString()),
  26. new AntPathRequestMatcher(this.adminServer.path("/instances/*"),
  27. HttpMethod.DELETE.toString()),
  28. new AntPathRequestMatcher(this.adminServer.path("/actuator/**"))
  29. ))
  30. .rememberMe((rememberMe) -> rememberMe.key(UUID.randomUUID().toString()).tokenValiditySeconds(1209600));
  31. }
  32. // Required to provide UserDetailsService for "remember functionality"
  33. @Override
  34. protected void configure(AuthenticationManagerBuilder auth) throws Exception {
  35. auth.inMemoryAuthentication().withUser(security.getUser().getName())
  36. .password("{noop}" + security.getUser().getPassword()).roles("USER");
  37. }
  38. }

第三步:服务端的yml配置文件配置admin登录页面的用户名和密码

  1. spring.security.user.name=123456
  2. spring.security.user.password=123456

第四步:注册到服务端的客户端配置文件也需要配置登录的用户名和密码,格式如下

  1. spring.boot.admin.client:
  2. username: 123456
  3. password: 123456

这样就算是实现了安全防护。

当然,SpringBoot除了可以注册单个客户端,也可以注册注册中心的客户端,就可以监控整个注册中心中的应用和服务。

④、邮件通知

SpringBootAdmin支持客户端服务发生异常时的通知,包括邮箱通知,钉钉或者其他的方式,具体参考官网:

Spring Boot Admin Reference Guideicon-default.png?t=N7T8https://docs.spring-boot-admin.com/2.5.1/#_notifications第一步:引入依赖(服务端)

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-mail</artifactId>
  4. </dependency>

第二步:配置邮箱信息,发件人和收件人

  1. #发件人用qq邮箱服务,发件人的用户名和密码,密码是授权码
  2. spring.mail.host=smtp.qq.com
  3. spring.mail.username=123456789@qq.com
  4. spring.mail.password=1234567889
  5. #收件人,多个人用,分割
  6. spring.boot.admin.notify.mail.from=123456789@qq.com
  7. spring.boot.admin.notify.mail.to=123456789@qq.com

上面的邮箱使用实际的邮箱,邮箱密码其实是qq邮箱是授权码

授权获取方式在qq邮箱后台设置里面获取:

根据指引获取授权码即可。

当服务挂了(或者重启)以后,就会有邮件发送出来

练习源码已上传:https://download.csdn.net/download/ywanju/89053368icon-default.png?t=N7T8https://download.csdn.net/download/ywanju/89053368

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/340038
推荐阅读
相关标签
  

闽ICP备14008679号