Springboot快速上手- 第八篇 Actuator

烂漫一生 提交于 2020-08-08 19:38:14

1 概述

Spring Boot Actuator的关键特性是在应用程序里提供众多Web端点,通过它们了解应用程序运行时的内部状况,比如:  Spring应用程序上下文里配置的Bean Bean在Spring应用程序上下文里是如何组装在一 起的 Spring Boot的自动配置做的决策 应用程序取到的环境变量、系统属性、配置属性和命令行参数 应用程序里线程的当前状态 应用程序最近处理过的HTTP请求的追踪情况 各种和内存用量、垃圾回收、Web请求以及数据源用量相关的指标……  Spring Boot Actuator提供的端点,可以查看官方文档: https://docs.spring.io/spring-boot/docs/2.0.0.M4/reference/htmlsingle/#production-ready-endpoints

2 启用Actuator

image.png

要启用Actuator的端点,只需在项目中引入Actuator的起步依赖即可

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

同时在properties里面设置management.security.enabled=false image.png

3 autoconfig

该端点用来获取应用的自动化配置报告,其中包括所有自动化配置的候选项。同时还列出了每个候选项自动化配置应用或未应用的原因。该报告内容将自动化配置内容分为两部分:

  • positiveMatches中返回的是条件匹配成功的自动化配置
  • negativeMatches中返回的是条件匹配不成功的自动化配置

4 beans

该端点用来获取应用上下文中创建的所有Bean

5 configprops

该端点用来获取应用中配置的属性信息报告

6 env

用来获取应用所有可用的环境属性报告。包括:环境变量、JVM属性、应用的配置配置、命令行中的参数。

7 health

用来获取应用的各类健康指标信息。springboot自带了一些常用资源的健康指标检测器,都通过HealthIndicator接口实现,并且会实现自动化装配,可以查看官方目前提供的HealthIndicators。

8 自定义health检测器

1:写一个类实现HealthIndicator接口,并注册为bean 2:在实现方法中使用Health类

9 info

用来返回一些应用自定义的信息。默认返回一个空的json串。可以在配置文件中通过info前缀来设置一些属性,如:info.app.author=cc

10 metrics

image.png

用来返回当前应用的各类重要度量指标,比如:

1:系统信息:包括处理器数量processors、运行时间uptime和instance.uptime、系统平均负载systemload.average 2:mem.:内存概要信息,包括分配给应用的总内存数量以及当前空闲的内存数量 3:heap.:堆内存使用情况 4:nonheap.:非堆内存使用情况 5:threads.:线程使用情况,包括线程数、守护线程数(daemon)、线程峰值(peak)等 6:classes.:应用加载和卸载的类统计 7:gc.:垃圾收集器的详细信息,包括垃圾回收次数gc.ps_scavenge.count、垃圾回收消耗时间gc.ps_scavenge.time、标记-清除算法的次数gc.ps_marksweep.count、标记-清除算法的消耗时间gc.ps_marksweep.time 8:httpsessions.:Web容器的会话使用情况。包括最大会话数httpsessions.max和活跃会话数httpsessions.active。该度量指标信息仅在引入了嵌入式Tomcat作为应用容器的时候才会提供。 9:gauge.:表示一个绝对数值的指标 10:counter.*:主要作为计数器来使用,记录了增加量和减少量

11 自定义Counter

1:需要注入计数服务: @Autowired private CounterService counterService; @Autowired private GaugeService gaugeService;

2:直接使用计数服务来计数

counterService.increment("abc.call.count"); gaugeService.submit("cc.redis.hit", 79);

12 mappings

用来返回所有Spring MVC的控制器映射关系

13 dump

用来暴露程序运行中的线程信息

14 trace

用来返回基本的HTTP跟踪信息。默认情况下,跟踪信息的存储采用org.springframework.boot.actuate.trace.InMemoryTraceRepository实现的内存方式,始终保留最近的100条请求记录

15 shutdown

用来提供远程关闭应用的功能,比较危险,建议不要打开。

16 常见配置

image.png

1:修改端点名称 直接配置endpoints.endpoint-id.id ,例如:endpoints.beans.id=bs 这么设置过后,访问就不是: http://localhost:8080/beans,而是: http://localhost:8080/bs 2:启用和禁用端点 设置endpoints.endpoint-id.enabled 3:设置管理端口 management.port ,-1表示关闭Http访问端口 4:设置管理地址 management.address=127.0.0.1 5:设置指定的根路径 management.context-path=/admin

cc老师2020年高级架构师系统培训课程7月6号正式开课,现在618活动,限时折扣中。至少300学时录播课程,60小时直播课,内容包含最新架构体系,现主流的架构,以及即时更新最新的技术,从理论到实践,以及如何解决问题。面试常用的 Netty,Redis,Kafka,Zookeeper,Dubbo, Nginx + openResty + kong + Lua, ElasticSearch等技术都深入源码层级,轻松掌握这些技术,从容应对面试。对于有想跟我一样有着像提高自身技术的同学,课程的详情都在私塾的首页详细说明了,感兴趣的小伙伴,可以一起去 【私塾在线 】 学习

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!