浅谈SpringBoot2.3 新特配置文件属性跟踪

这篇文章主要介绍了浅谈SpringBoot2.3 新特配置文件属性跟踪,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

背景

当我们使用 spring boot 在多环境打包,配置属性在不同环境的值不同,如下:

 spring: profiles: active: @project.profile@ #根据maven 动态配置profile --- spring: profiles: dev demo: lengleng_dev --- spring: profiles: prd demo: lengleng_prd 

或者使用 spring cloud 配置中心 (nacos/config)等

再有就是 应用配置的同一个属性,值的来源可能来自配置文件、环境变量、启动参数等等。 很多情况由于如上配置的复杂性,应用在读取配置的时候,并不是我们预期的值,比如我们想使用是配置文件 dev 环境的值,却被环境变量的 或者其他的数据覆盖等,这些往往只有等我们运行时,输出日志才能发现错误原因。

解决方案

spring boot 2.3 Actuator 提供 /actuator/configprops 端点 (之前版本也有此端点,但是行为发生变化了 /actuator/env 保持一致 ),提供对配置文件属性跟踪功能,方便我们在 spring boot 应用中,实时的获取配置文件实际加载值。

如何使用

引入 actuator 依赖

  org.springframework.bootspring-boot-starter-actuator

暴露 configprops 端点

 management: endpoints: web: exposure: include: 'configprops'

对应配置类

 @Data @Component @ConfigurationProperties("demo") public class DemoConfig { private String username; private String password; } 

访问 Endpoint 实时获取配置文件的值

特殊说明

configprops Endpoint 会对敏感字段默认脱敏 ,默认关键字类

 public class Sanitizer { private static final String[] REGEX_PARTS = { "*", "$", "^", "+" }; private static final Set DEFAULT_KEYS_TO_SANITIZE = new LinkedHashSet<>(Arrays.asList("password", "secret", "key", "token", ".*credentials.*", "vcap_services", "sun.java.command")); } 

配置个性化脱敏规则

 management: endpoint: configprops: keys-to-sanitize: - 'aaa' - 'bbb' 

当配置类的某个属性值为空时, 通过 /actuator/configprops 访问,不会展示此属性。

总结

configprops 端点对应 ConfigurationPropertiesReportEndpoint 类, 通过阅读 可以了解从 PropertySource 获取配置的技巧
应用场景: CI 在执行单元测试的前置应该通过此端点判断配置是否和预期一致,避免无用执行条件

以上源码可以参考: https://github.com/lltx/spring-boot-course

到此这篇关于浅谈SpringBoot2.3 新特配置文件属性跟踪的文章就介绍到这了,更多相关SpringBoot2.3 文件属性跟踪内容请搜索html中文网以前的文章或继续浏览下面的相关文章希望大家以后多多支持html中文网! 

以上就是浅谈SpringBoot2.3 新特配置文件属性跟踪的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » Java