java spring 本地缓存,Springboot 如何使用本地缓存Caffeine

Springboot 如何使用本地缓存Caffeine

发布时间:2020-11-17 14:04:12

来源:亿速云

阅读:154

作者:Leah

本篇文章为大家展示了Springboot 如何使用本地缓存Caffeine,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

Caffeine是使用Java8对Guava缓存的重写版本性能有很大提升

一 依赖

org.springframework.boot

spring-boot-starter-cache

com.github.ben-manes.caffeine

caffeine

2.7.0

二 配置缓存,单独使用

只需要配置Bean就可以了,然后进行数据读写,注意这里提供了很多强大的自定义配置,可以查看文档详细配置

//定义缓存,可直接使用

@Bean

public LoadingCache expiryCache(){

LoadingCache loadingCache = Caffeine.newBuilder()

.initialCapacity(100)

.maximumSize(1000)

//缓存写入/删除监控

.writer(new CacheWriter() {

@Override

public void write(Object key, Object value) { //此方法是同步阻塞的

System.out.println("--缓存写入--:key=" + key + ", value=" + value);

}

@Override

public void delete(Object key, Object value, RemovalCause cause) { System.out.println("--缓存删除--:key=" + key); }

})

.expireAfterAccess(1, TimeUnit.MINUTES) //过期时间

.build((String key)->"刷新的数据"); //cacheload实现类,刷新时候调用

loadingCache.put("name","侯征");

return loadingCache;

}

测试使用:

@Autowired

private LoadingCache loadingCache;

@GetMapping("/get")

public Object getValue(String key){

return loadingCache.get(key);

}

@GetMapping("/add")

public void addValue(String value){

loadingCache.put(value,value);

}

@GetMapping("/delete")

public void deleteValue(String key){

loadingCache.invalidate(key);

loadingCache.invalidateAll();//清楚所有

}

@GetMapping("/refresh")

public void refreshValue(String key){

//刷新时会根据build方法中中指定的cacheload重新加载

loadingCache.refresh(key);

}

三 配置CacheManager,和spring缓存注解一起使用

//配置CacheManager

@Bean(name = "caffeine")

public CacheManager cacheManagerWithCaffeine() {

CaffeineCacheManager cacheManager = new CaffeineCacheManager();

Caffeine caffeine = Caffeine.newBuilder()

//cache的初始容量值

.initialCapacity(100)

//maximumSize用来控制cache的最大缓存数量,maximumSize和maximumWeight(最大权重)不可以同时使用,

.maximumSize(1000)

//最后一次写入或者访问后过久过期

.expireAfterAccess(500, TimeUnit.SECONDS)

//创建或更新之后多久刷新,需要设置cacheLoader

.refreshAfterWrite(10, TimeUnit.SECONDS);

cacheManager.setCaffeine(caffeine);

cacheManager.setCacheLoader(cacheLoader);

cacheManager.setCacheNames(names);//根据名字可以创建多个cache,但是多个cache使用相同的策略

cacheManager.setAllowNullValues(false);//是否允许值为空

return cacheManager;

}

配置 cacheload

/**

* 必须要指定这个Bean,refreshAfterWrite配置属性才生效

*/

@Bean

public CacheLoader cacheLoader() {

return new CacheLoader() {

@Override

public Object load(Object key) throws Exception { return null;}

// 重写这个方法将oldValue值返回回去,进而刷新缓存

@Override

public Object reload(Object key, Object oldValue) throws Exception {

System.out.println("--refresh--:"+key);

return oldValue;

}

};

}

其他就是在service中配置spring的几个缓存注解使用就行了,这里放一张截图,这些注解用法,网上很多:[/code]

c0c73497d0098e0db9cafa0bdfedab05.png

上述内容就是Springboot 如何使用本地缓存Caffeine,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值