SpringBoot 常用读取配置文件的 3 种方法!( 二 )

3、使用@ConfigurationPropertiesScan扫描在 Spring Boot 2.2.0.RELEASE 中提供了一个扫描注解@ConfigurationPropertiesScan 。它可以扫描特定包下所有的被@ConfigurationProperties标记的配置类,
并将它们进行IoC注入 。
@ConfigurationPropertiesScan@SpringBootApplicationpublic class MainApplication {public static void main(String[] args) {SpringApplication.run(MainApplication.class, args);}}三、使用 Environment 读取配置文件Environment 是 SpringCore 中的一个用于读取配置文件的类,将此类使用 @Autowired 注入到类中就可以使用它的getProperty方法来获取某个配置项的值 。
如下代码所示:
@SpringBootApplicationpublic class MainApplication implements InitializingBean {@Autowiredprivate Environment environment;public static void main(String[] args) {SpringApplication.run(MainApplication.class, args);}@Overridepublic void afterPropertiesSet() {String username = environment.getProperty("rabbitmq.username");System.out.println("rabbitmq当前用户名为:" + username);}}四、常用的几种数据结构配置读取比如我们常见的字符串、整数、List、Map如何配置和读取呢?这里以之前自己开发的一个项目中用到复杂的配置数据来做示例之前有发布一个基于
Spring Cache实现二级缓存(Caffeine+Redis) 的项目,里面的配置就比较复杂 。
具体项目地址:基于Spring Cache实现分布式二级缓存
这里展示配置示例:
application.yml
# 二级缓存配置l2cache:config:# 是否存储空值,默认true,防止缓存穿透allowNullValues: true# 组合缓存配置composite:# 是否全部启用一级缓存,默认falsel1AllOpen: false# 是否手动启用一级缓存,默认falsel1Manual: true# 手动配置走一级缓存的缓存key集合,针对单个key维度l1ManualKeySet:- userCache:user01- userCache:user02- userCache:user03- userCache:user04# 一级缓存caffeine:# 缓存刷新调度线程池的大小refreshPoolSize: 2# 写入后过期时间(秒)expireAfterWrite: 180# 访问后过期时间(秒)expireAfterAccess: 180# 初始化大小initialCapacity: 100# 最大缓存对象个数,超过此数量时之前放入的缓存将失效maximumSize: 300# 二级缓存redis:# 全局过期时间,单位毫秒,默认不过期defaultExpiration: 300000# 每个cacheName的过期时间,单位毫秒expires: {userCache: 300000,goodsCache: 50000}# 缓存更新时通知其他节点的topic名称 默认 cache:redis:caffeine:topictopic: cache:redis:caffeine:topic配置实体类
@Data@ConfigurationProperties(prefix = "l2cache")public class L2CacheProperties {/*** 缓存配置*/private L2CacheConfig config;}L2CacheConfig
/** *缓存配置 * * @author xub * @date 2022/9/20 下午6:02 */@Datapublic class L2CacheConfig {/** 是否存储空值,设置为true时,可防止缓存穿透 */private boolean allowNullValues = true;/** 组合缓存配置 */private final Composite composite = new Composite();/** 一级缓存配置 */private final Caffeine caffeine = new Caffeine();/** 二级缓存配置 */private final Redis redis = new Redis();/*** 组合缓存配置*/@Datapublic static class Composite {/** 是否全部启用一级缓存,默认false*/private boolean l1AllOpen = false;/** 是否手动启用一级缓存,默认false */private boolean l1Manual = false;/** 手动配置走一级缓存的缓存key集合,针对单个key维度*/private Set<String> l1ManualKeySet = new HashSet<>();}/*** 一级缓存配置*/@Datapublic static class Caffeine {/** 缓存刷新调度线程池的大小 默认为 CPU数 * 2 */private Integer refreshPoolSize = Runtime.getRuntime().availableProcessors();/** 写入后过期时间,单位秒 */private long expireAfterWrite;/** 写入后刷新时间,单位秒 */private long refreshAfterWrite;/** 初始化大小 */private int initialCapacity;/** 最大缓存对象个数,超过此数量时之前放入的缓存将失效 */private long maximumSize;}/*** 二级缓存配置*/@Datapublic static class Redis {/** 全局过期时间,单位毫秒,默认不过期 */private long defaultExpiration = 0;/** 每个cacheName的过期时间,单位毫秒,优先级比defaultExpiration高 */private Map<String, Long> expires = new HashMap<>();/** 缓存更新时通知其他节点的topic名称 */private String topic = "cache:redis:caffeine:topic";}}

经验总结扩展阅读