1,官网wiki
2,api
3,引入pom依赖,注意caffeine版本,如果springboot版本太低引入高版本caffeine会报错
倾向于只使用caffeine提供的pom,不用springboot集成的 cache start,如下
<!--caffeine本地缓存-->
<dependency>
<groupId>com.github.ben-manes.caffeine</groupId>
<artifactId>caffeine</artifactId>
<version>2.9.3</version>
</dependency>
4,Caffeine提供了四种缓存添加策略:手动加载,自动加载,手动异步加载和自动异步加载。
5,spring配置bean,这里使用手动加载策略,配置的bean中可自定义线程池
@Configuration
public class CacheConfig {
/**
* 默认缓存配置,key为string,value为object,如果value想自定义为目标对象,可新建一个@Bean
*
* @return
*/
@Bean(name = "caffeineCache")
public Cache<String, Object> caffeineCache() {
return Caffeine.newBuilder()
// 设置最后一次写入或访问后经过固定时间过期
.expireAfterWrite(60 * 10, TimeUnit.SECONDS)
// 缓存的最大条数
.maximumSize(1000)
.build();
}
@Bean(name = "caffeineCacheString")
public Cache<String, String> caffeineCacheString() {
return Caffeine.newBuilder()
// 设置最后一次写入或访问后经过固定时间过期
.expireAfterWrite(60 * 10, TimeUnit.SECONDS)
// 缓存的最大条数
.maximumSize(1000)
.build();
}
}
6,缓存模板类,省略
7,使用
CacheTemplate<List<MenuInfo>> cacheTemplate = new CacheTemplate() {
@Override
protected List<MenuInfo> getDB() {
return menuInfoMapper.getTreeList();
}
};
List<MenuInfo> menuList = cacheTemplate.getCaffeine("test", caffeineCache);