Actuator 是 Spring Boot 提供的对应用系统的自省和监控功能,通过 Actuator,可以使用数据化的指标去度量应用的运行情况,比如查看服务器的磁盘、内存、CPU等信息,系统的线程、gc、运行状态等等。
访问 localhost:8081/actuator ,结果如下图
可以看出此时只显示了 /health 和 /info 两个端点 ,这是为了程序的安全性考虑,默认只开启这两个端口, 如果想显示所有端口, 可以进行如下配置:
management: server: port: 8081 endpoints: web: exposure: include: "*"如果想自定义端口, 配置如下:
management: server: port: 8081 endpoints: web: exposure: include: info,beans,health,env下面表格列举了Actuator的端点说明:
端点描述auditevents获取当前应用暴露的审计事件信息beans获取应用中所有的 Spring Beans 的完整关系列表caches获取公开可以用的缓存conditions获取自动配置条件信息,记录哪些自动配置条件通过和没通过的原因configprops获取所有配置属性,包括默认配置,显示一个所有 @ConfigurationProperties 的整理列版本env获取所有环境变量flyway获取已应用的所有Flyway数据库迁移信息,需要一个或多个 Flyway Beanliquibase获取已应用的所有Liquibase数据库迁移。需要一个或多个 Liquibase Beanhealth获取应用程序健康指标(运行状况信息)httptrace获取HTTP跟踪信息(默认情况下,最近100个HTTP请求-响应交换)。需要 HttpTraceRepository Beaninfo获取应用程序信息integrationgraph显示 Spring Integration 图。需要依赖 spring-integration-coreloggers显示和修改应用程序中日志的配置logfile返回日志文件的内容(如果已设置logging.file.name或logging.file.path属性)metrics获取系统度量指标信息mappings显示所有@RequestMapping路径的整理列表scheduledtasks显示应用程序中的计划任务sessions允许从Spring Session支持的会话存储中检索和删除用户会话。需要使用Spring Session的基于Servlet的Web应用程序shutdown关闭应用,要求endpoints.shutdown.enabled设置为true,默认为 falsethreaddump获取系统线程转储信息heapdump返回hprof堆转储文件jolokia通过HTTP公开JMX bean(当Jolokia在类路径上时,不适用于WebFlux)。需要依赖 jolokia-coreprometheus以Prometheus服务器可以抓取的格式公开指标。需要依赖 micrometer-registry-prometheus对于正在生产环境上运行的程序来说端点是比较敏感的,我们并不希望别人恶意的去访问端点,特别是
/shutdown 这样的端点。
当我们使用 POST 方式请求 /shutdown 时,可以直接将应用关闭,如下图
因此,我们需要通过management.endpoint.shutdown.enabled = false来关闭此端点。