四、常用的几种数据结构配置读取比如我们常见的字符串、整数、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";}}
Configuration类
@Configuration@EnableConfigurationProperties(L2CacheProperties.class)public class CacheRedisCaffeineAutoConfiguration {@Autowiredprivate L2CacheProperties l2CacheProperties;@Beanpublic RedisCaffeineCacheManager cacheManager() {return new RedisCaffeineCacheManager(l2CacheProperties.getConfig());}}
测试
项目启动后,进行Debug打断点,看有木有注入到L2CacheProperties实体中
文章插图
通过上面截图就可以看出,所有application.yml配置数据,都已经在L2CacheProperties实体中,说明配置成功,获取也成功了 。
推荐阅读
- 含源码 手把手教你使用LabVIEW人工智能视觉工具包快速实现图像读取与采集
- 之三 2流高手速成记:SpringBoot整合mybatis/mybatis-plus实现数据持久化
- Optional 常用方法总结
- 财务软件哪一个好用
- 什么是辅料缝纫线常用的有哪些
- 常用的办公设备有哪些作用各是什么 常用的办公设备有哪些
- hadoop中常用的命令实验报告 hadoop中常用的命令
- EXCEL常用的制表方法和技巧
- 微信保存的文件在哪里找得到 微信保存的文件在哪里
- 夜郎是什么生肖动物 夜郎是什么动物