缓存,在开发中是很是经常使用的。在高并发系统中,若是没有缓存,纯靠数据库来扛,那么数据库压力会很是大,搞很差还会出现宕机的状况。本篇文章,将会带你们学习Spring Cache缓存框架。html
本文发布于掘金号【Happyjava】。Happy的掘金地址:juejin.im/user/5cc289…,Happy的我的博客:blog.happyjava.cn。欢迎转载,但须保留此段声明。java
经过Spring initialise快速建立SpringBoot工程,能够参考:blog.happyjava.cn/articles/7.…nginx
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
复制代码
@Configuration
@EnableCaching
public class CacheConfig {
/** * 默认就是这种配置,能够不写 */
@Bean
public CacheManager cacheManager() {
return new ConcurrentMapCacheManager();
}
}
复制代码
在SpringBoot中,默认就是ConcurrentMapCacheManager的缓存方式,不写也是能够的。这里能够经过CacheManager配置不一样的缓存实现方式,好比redis,EHCACHE等。这个在下个章节再讲解。git
ConcurrentMapCacheManager还有一个不定参数的重载构造方法,github
它接收的是cacheName入参,若是设置了缓存名字,那么后续的方法就只能使用在这里设置的缓存,不然会抛出异常。若是是无参构造方法,那么它是一个可变的缓存管理器。redis
Cacheable注解是用来设置缓存的。经常使用注解以下:spring
指定使用的缓存,其实也就是上面说到的cacheName。若是是无参的ConcurrentMapCacheManager,那么这里能够根据本身的用途等因素自定义便可。数据库
缓存的key,就跟Map同样,是操做缓存的键。缓存
这里接受的是 SpEL表达式。关于SpEL表达式,下面作个简要说明:springboot
有以下方法:
@CachePut(value = "listUsers", key = "#username")
public List<String> updateCache(String username) {
System.out.println("执行了updateCache方法");
return Arrays.asList("Happyjava", "Hello-SpringBoot", System.currentTimeMillis() + "");
}
复制代码
能够经过 #paramName 的方式得到入参
还有一个是root对象,用法以下:
@CachePut(value = "listUsers", key = "#root.methodName+#username")
public List<String> updateCache(String username) {
System.out.println("执行了updateCache方法");
return Arrays.asList("Happyjava", "Hello-SpringBoot", System.currentTimeMillis() + "");
}
复制代码
其实不必记住,经过IDEA的智能提示灵活使用便可:
各个参数表明的意思,相信你们一目了然。
缓存控制条件,若是使用了该字段,那么只有结果为true时,才会缓存结果。
@Cacheable(value = "listUsers", condition = "#username.length()>5")
public List<String> listUsers(String username) {
System.out.println("执行了listUsers方法");
return Arrays.asList("Happyjava", "Hello-SpringBoot", System.currentTimeMillis() + "");
}
复制代码
下面贴出一个设置缓存的例子:
@Cacheable(value = "listUsers", key = "#root.methodName+#username", condition = "#username.equals('Happyjava')")
public List<String> listUsers(String username) {
System.out.println("执行了listUsers方法");
return Arrays.asList("Happyjava", "Hello-SpringBoot", System.currentTimeMillis() + "");
}
复制代码
只有当入参username等于"Happyjava"的时候,才会缓存结果,能够经过是否屡次打印:"执行了listUsers方法"来判断。
相信HTTP协议熟悉的朋友一看名字就知道这个注解是干吗用的了。咱们能够经过CachePut注解来更新缓存。其经常使用注解与Cacheable是一致的。下面给出一个更新缓存的例子:
@CachePut(value = "listUsers", key = "#username", condition = "#username.equals('Happyjava')")
public List<String> updateCache(String username) {
System.out.println("执行了updateCache方法");
return Arrays.asList("Happyjava", "Hello-SpringBoot", System.currentTimeMillis() + "");
}
复制代码
咱们能够写一个value和key与之对应的Cacheable注解进行测试:
@Cacheable(value = "listUsers", key = "#username", condition = "#username.equals('Happyjava')")
public List<String> listUsers(String username) {
System.out.println("执行了listUsers方法");
return Arrays.asList("Happyjava", "Hello-SpringBoot", System.currentTimeMillis() + "");
}
复制代码
测试预期的结果是:调用了CachePut方法后,Cacheable方法会返回一个新的结果。
这是一个删除注解。经常使用参数除了上面两个注解列出的三个以外,还有一个allEntries,这是一个布尔类型的参数,默认为false,其意思是“是否删除全部缓存”。在false的状况下,只是删除与key相对应的缓存,若是为true,则会删除全部缓存(固然是对应的value下的)。
@CacheEvict(value = "listUsers", key = "#username")
public void deleteCache(String username) {
System.out.println("执行了deleteCache方法");
}
@CacheEvict(value = "listUsers", allEntries = true)
public void deleteAllCache() {
}
复制代码
固然,这只是Spring cache的一个快速上手示例,其实咱们更多时候不是这么使用的。在实际项目中,更可能是配合redis进行使用的,这个放在下篇文章讲解吧(其实也就是一些配置的事情)
搜索公众号【Happyjava】,回复【电子书】和【视频】,便可获取大量优质电子书和大数据、kafka、nginx、MySQL等视频资料