概述
Caffeine 是基于Java 8的高性能,接近最佳的缓存库
1、引入依赖
<dependency>
<groupId>com.github.ben-manes.caffeine</groupId>
<artifactId>caffeine</artifactId>
<version>2.8.2</version>
</dependency>
2、定义
private final Cache<String, List<Object>> bonusDetailRuleCache = Caffeine
.newBuilder()
//最大容量
.maximumSize(100)
//最后一次使用过后算起的过期时间
.expireAfterWrite(Duration.ofMinutes(10))
.build();
Caffeine提供了基于大小的驱除策略:
使用Caffeine.maximumSize(long)方法来指定缓存的最大容量。当缓存超出这个容量的时候,会使用Window TinyLfu策略来删除缓存。我们也可以使用权重的策略来进行驱逐,可以使用Caffeine.weigher(Weigher) 函数来指定权重,使用Caffeine.maximumWeight(long) 函数来指定缓存最大权重值。
Caffeine提供了三种定时驱逐策略:
expireAfterAccess(long, TimeUnit):在最后一次访问或者写入后开始计时,在指定的时间后过期。假如一直有请求访问该key,那么这个缓存将一直不会过期。
expireAfterWrite(long, TimeUnit): 在最后一次写入缓存后开始计时,在指定的时间后过期。
expireAfter(Expiry): 自定义策略,过期时间由Expiry实现独自计算。
还有其他的一些,刷新,写入,监听等功能就不再赘述啦~各位看官自查
3、使用
一般使用
List<Object> list = bonusDetailRuleCache.get("", key -> Service.select());
这样就可以从缓存中查找数据,如果,缓存没有这个key(“”)相关的数据或者过期,就会重新通过service查一遍
可以利用缓存来,存储一些不经常变动和一些热点数据
最后
以上就是羞涩哑铃为你收集整理的Java Caffeine 缓存框架的应用1、引入依赖2、定义3、使用的全部内容,希望文章能够帮你解决Java Caffeine 缓存框架的应用1、引入依赖2、定义3、使用所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复