一、概述
我们在研发过程中,经常会进行数据库查询操作,对于需要频繁查询的数据,每次都从数据库中查询效率比较低,因此我们可以应用缓存技术。SpringBoot自带的Cache是一个比较不错的选择。
SpringBoot Cache主要有三个注解,@Cacheable、@CachePut、@CacheEvict。下面分别说下每个注解的含义:
@Cacheable:在方法体上加上此注解,表示若缓存中存在缓存组件,则直接返回,若不存在,则执行方法体,常用属性有以下几项:
cacheNames/value | 缓存组件的名字,如value="xxx",value和cacheNames意思一致,使用一个 |
key | 缓存数据时使用的 key,可以用它来指定。默认是使用方法参数的值。(这个 key 你可以使用 spEL 表达式来编写) 如key="#id"(id为方法参数),也可以用表达式,如key="#id+#name" |
condition | 可以用来指定符合条件的情况下才缓存 |
sync | 是否使用异步模式,默认为false |
@CachePut:在方法体上加此注解,表示不论缓存中是否存在,都执行方法体,并将结果放入缓存
属性除了没有sync,其它和@Cacheable一致
@CacheEvict:方法体上加此注解,表示删除缓存中的数据,属性如下:
cacheNames/value | 与@Cacheable注解中含义一致 |
key | 与@Cacheable注解中含义一致,设置key值后,表示只删除指定的key,缓存中其它的key值数据不影响 |
allEntries | 是否删除缓存中所有的数据,布尔型,默认为false。若设置为true,缓存中所有的key值都将被删除 |
二、应用
pom依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
<groupId>com.github.ben-manes.caffeine</groupId>
<artifactId>caffeine</artifactId>
</dependency>
增加配置
@Configuration
@EnableCaching
public class CacheConfig {
@Bean
public CacheManager cacheManager(){
SimpleCacheManager cacheManager = new SimpleCacheManager();
List<CaffeineCache> list = new ArrayList<>();
list.add(new CaffeineCache("cacheList",
Caffeine.newBuilder()
.initialCapacity(50)
.maximumSize(1000)
.expireAfterAccess(5, TimeUnit.MINUTES)
.build()
));
cacheManager.setCaches(list);
return cacheManager;
}
}
具体使用
//结果加入缓存,cacheList中无此key则执行方法体,有则直接从缓存中获取
@Cacheable(value = "cacheList", key = "#key")
public ExRuleVO getRuleInfo(String key) {
//查询数据库
return null;
}
//删除缓存,从cacheList中删除key值为变量key的缓存
@CacheEvict(value = "cacheList", key = "#key")
public void delRuleCache(String key){
}