本文记录学习在SpringBoot中使用Cache。java
缓存是一个数据交换的缓冲区,在一些条件下能够替代数据库。举个例子:咱们有一个查询的业务,访问数据的频率特别高,且每次访问时的查询条件都同样,数据库的数据一直保存不变,这样咱们每次查询出来的结果都是同样的。为了下降高频率访问数据库给数据库带来的压力,咱们能够在第一次访问后把数据缓存起来,之后再作相同查询时只去缓存中取数据,而不用取数据库再作查询。spring
SpringBoot对缓存作了支持以供咱们方便快速的使用,咱们只须要引入相关依赖就能够了。在项目启动时会自动根据配置进行识别和初始化操做。数据库
在pom.xml文件中引入对Cache支持的依赖缓存
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
要使用Cache,咱们必须在启动时开启Cache,@EnableCaching 说明开启缓存app
@SpringBootApplication
@EnableCaching
public class CacheApplication {
public static void main(String[] args) {
SpringApplication.run(CacheApplication.class, args);
}
}
Spring Cache有3个比较重要的注解@Cacheable,@CachePut,@CacheEvict,咱们一个一个说明:函数
这个注解代表对操做进行缓存,它能够放在类上,代表对当前类中全部的方法的结果进行缓存;也能够放在方法上,代表对当前方法的结果进行缓存。它有3个参数:spring-boot
Value 缓存的名称学习
Key 缓存的键,能够为空,若是指定要按照 SpEL 表达式编写;若是不指定,则缺省按照方法的全部参数进行组合ui
Condition 缓存触发的条件,返回值是true和false,只有知足条件的状况(true)才会加入缓存,默认为空,既表示所有都加入缓存,支持 SpEL表达式。spa
实现代码
@RestController
public class CacheController {
@RequestMapping("/hello")
@Cacheable(value="helloCache", key = "#name", condition = "#name.length()>2")
public String hello(@RequestParam(value="name", required = true) String name){
System.out.println("没有走缓存,去数据库查询数据");
return "hello,"+name;
}
}
咱们的方法中有一个参数,模拟数据库查询时的条件,如上,当咱们的参数name的长度大于2时,参数加入的缓存中。若是咱们请求http://localhost:8080/hello?name=ch,无论咱们请求多少次控制台中都会打印出‘没有走缓存,去数据库查询数据’,说明缓存没有触发,若是咱们请求http://localhost:8080/hello?name=cache,第一次请求时控制台会打印出‘没有走缓存,去数据库查询数据’,以后不会再有,说明在方法执行前会先去缓存中看是否有结果,有则返回结果,没则执行请求方法,如第一次请求时执行后已经对结果进行了缓存,咱们再请求时会直接去缓存中取结果,不会再去执行方法请求数据库了。
它与@Cacheable相似,都是说明要作缓存,并且属性Key,Value,Condition的用法都同样,也可使用在类或者方法上,区别是它每次都会执行实际方法(如查询数据库)
代码实现
@RequestMapping("/hello1")
@CachePut(value="helloCache", key = "#name", condition = "#name.length()>2")
public String hello1(@RequestParam(value="name", required = true) String name){
System.out.println("没有走缓存,去数据库查询数据");
return "hello,"+name;
}
当咱们请求http://localhost:8080/hello1?name=cache时,无论咱们请求第几回,都会在控制台输出‘没有走缓存,去数据库查询数据’。若是数据库数据发生了变化,则会用新的数据替换以前的同value同Key缓存的数据。
它是用来清除缓存的,一样是能够标记在类和方法上,标记在类上时说明全部方法都会清除缓存。Key,Value,Condition属性用法与Cacheable同样,还有2个属性allEntries和beforeInvocation。
allEntries表示是否删除缓存中的全部属性,默认是false,表示不,true表示是。当被指定为true时,会忽略掉指定的Key而删除全部。
beforeInvocation表示删除缓存的时机,默认是false,表示在方法执行完后才删除缓存,true表示在方法执行前就先删除缓存。在方法执行过程当中若是发生了异常,默认设置下(false)将不能删除掉缓存。
代码实现
@RequestMapping("/hello2")
@CacheEvict(value="helloCache", key="#name", condition="#name.length()>2", allEntries = true, beforeInvocation = true)
public String hello2(@RequestParam(value="name", required = true) String name){
System.out.println("CacheEvict 清除缓存");
return "hello,"+name;
}
使用一样的参数如cache,先请求执行hello方法进行数据缓存,在执行hello2进行删除缓存操做,而后再执行hello1方法会发如今控制台上又输出了‘没有走缓存,去数据库查询数据’,说明执行hello2方法时已经将缓存删除掉了。
注:SpEL(Spring Expression Language)是一个支持运行时查询和操做对象图的强大的表达式语言,其语法相似于统一 EL,但提供了额外特性,显式方法调用和基本字符串模板函数。