美文网首页
关于缓存的一些总结(7)

关于缓存的一些总结(7)

作者: Y先生的领地 | 来源:发表于2021-03-10 13:30 被阅读0次

    本章节讲解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

    1. 编写配置文件 application.properties
      spring.cache.type=redis
    2. 缓存相关注解的解释
      @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

    image.png
    这样基本上以上问题都会得以解决。
    配置文件中还可以设置是否缓存空值:
    spring.cache.redis.cache-null-values=true
    便可以解决之前提到的缓存穿透问题。

    以上问题很好地解决了缓存的读取模式,我们如果是要更新缓存,便用到了这两个注解:
    @CacheEvict 将数据从缓存中删除 -->可以认为是缓存的失效模式
    @CachePut 在不影响方法执行时更新缓存 -->可以认为是缓存的双写模式

    至此我们时候从最刚开始的缓存三大问题,到现在,Spring Cache是否是终极方案呢?


    image.png

    我们发现SpringCache 基本上解决了缓存的三大问题,而且操作比较简单,只是面对缓存击穿问题,SpringCache默认是不加锁的,即使加上了sync=true ,也只是加了本地锁而已,那如果一个服务启动了7个应用,相当于有7把锁,不过也足够应对大部分场景了。好了,到此结束!

    特此声明:以上文章中的很多图都来自于网络,文字描述是自己的总结,感谢支持。

    相关文章

      网友评论

          本文标题:关于缓存的一些总结(7)

          本文链接:https://www.haomeiwen.com/subject/idrwqltx.html