关于缓存的一些总结(7)
本章节讲解Spring Cache
为啥要用Spring Cache组件呢?因为我们发现代码中使用缓存时步骤基本上都是一样的,首先查询缓存,如果缓存中有直接返回数据,如果缓存没有,查询数据库,并给缓存中存放一份,然后返回数据。每次都是如此,有没有一些工具类专门搞这一块内容呢?Java行业就是这样,只要有需求,就有人造轮子,现在就讲解一下这个神器--> Spring Cache
首先spring cache不是什么springboot中的什么注解,而是spring中的,而且是spring 3版本之后才支持的。
话不多说,走起!
1、引入依赖
spring-boot-starter-cache
spring-boot-starter-data-redis
2、写配置
1)自动化配置
CacheAutoConfiguration 已经导入了RedisCacheConfiguration,自动配置好了缓存管理器RedisCacheManager
- 编写配置文件 application.properties
spring.cache.type=redis - 缓存相关注解的解释
@Cacheable 触发将数据保存到缓存
@CacheEvict 将数据从缓存中删除
@CachePut 在不影响方法执行时更新缓存
@Caching: 组合以上多个操作
@CacheConfig: 在类级别共享缓存的相同配置
4)测试
1、开启缓存功能
在SpringBootApplication 入口类上添加@EnableCaching
2、只需要使用注解放在需要缓存的方法上即可
image.png
比如在方法上写上@Cacheable() 标注在某个方法上,该方法的返回结果变进入到缓存中,下次再方法便不会执行该方法了。
@Cacheable({"category"}) 括号里面的内容相当于是给缓存分区,通过名字分区,我们执行完方法查看redis,发现有数据
image.png
以上就是SpringCache 的入门示例,但也存在几点问题:
1、数据Json话存储
2、自定义redis的key值
3、数据没有过期时间
所以可以进一步配置:
1、如何定义key值
Cacheable注解中
@Cacheable(value={"category"},key="#root.method.name")
使用key="" 即可设置key值
2、配置过期时间
在配置文件中继续添加:
spring.cache.redis.time-to-live=3600000 //设置过期时间1小时
3、将数据变为json格式比较麻烦一些,需要编写一个配置类:MyRedisConfig.java
这样基本上以上问题都会得以解决。
配置文件中还可以设置是否缓存空值:
spring.cache.redis.cache-null-values=true
便可以解决之前提到的缓存穿透问题。
以上问题很好地解决了缓存的读取模式,我们如果是要更新缓存,便用到了这两个注解:
@CacheEvict 将数据从缓存中删除 -->可以认为是缓存的失效模式
@CachePut 在不影响方法执行时更新缓存 -->可以认为是缓存的双写模式
至此我们时候从最刚开始的缓存三大问题,到现在,Spring Cache是否是终极方案呢?
image.png
我们发现SpringCache 基本上解决了缓存的三大问题,而且操作比较简单,只是面对缓存击穿问题,SpringCache默认是不加锁的,即使加上了sync=true ,也只是加了本地锁而已,那如果一个服务启动了7个应用,相当于有7把锁,不过也足够应对大部分场景了。好了,到此结束!
特此声明:以上文章中的很多图都来自于网络,文字描述是自己的总结,感谢支持。