Spring boot actuator端点启用和暴露操作

启用端点

默认情况下,除了shutdown端点是关闭的,其它的都是启用的。配置一个端点的启用,使用management.endpoint…enabled属性,

下面的例子是启用shutdown端点:

management.endpoint.shutdown.enabled=true

如果你个人更喜欢自定义端点的启用和关闭,可以使用如下属性

management.endpoints.enabled-by-default=false

上面这个属性将关闭所有端点启用情况,自己可以单独的通过设置enabled属性启用端点;

下面的示例示关闭所有的端点,并且启用info端点:

management.endpoints.enabled-by-default = falsemanagement.endpoint.info.enabled = true

禁用端点会被从ApplicationContext上下文中删除,如果只是想从技术上更改端点的暴露,可以使用include和exclude属性替代。

公开端点

由于端点可能包含敏感信息,应该仔细的考虑什么时候暴露它们,

下面的表格展示了内置端点的暴露情况:

ID JMX Web auditevents 是 没有 beans 是 没有 caches 是 没有 conditions 是 没有 configprops 是 没有 env 是 没有 flyway 是 没有 health 是 是 heapdump N / A 没有 httptrace 是 没有 info 是 是 integrationgraph 是 没有 jolokia N / A 没有 logfile N / A 没有 loggers 是 没有 liquibase 是 没有 metrics 是 没有 mappings 是 没有 prometheus N / A 没有 scheduledtasks 是 没有 sessions 是 没有 shutdown 是 没有 threaddump 是 没有

要更改端点暴露,使用下面的特定技术include和 exclude特性:

属性 默认 management.endpoints.jmx.exposure.exclude management.endpoints.jmx.exposure.include * management.endpoints.web.exposure.exclude management.endpoints.web.exposure.include info, health

include属性列出暴露端点的ID,exclude属性列出不应该暴露端点的ID;exclude属性的优先级高于include属性,include和exclude属性都可以使用端点列表来配置ID。

例如

要停止通过JMX公开所有端点并仅显示端点health和 info端点,请使用以下属性:

management.endpoints.jmx.exposure.include=health,info

*可用于选择所有端点。例如,要通过HTTP公开除了env和beans端点之外的所有内容,请使用以下属性:

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

在YAML中有特殊的含义,所以如果想使用include或者exclude包含所有的端点时要加上双引号,如下示例:

management:  endpoints:    web:      exposure:        include: "*"

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

绊脚石乃是进身之阶。

Spring boot actuator端点启用和暴露操作

相关文章:

你感兴趣的文章:

标签云: