Spring Cache

Posted wyp1988

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring Cache相关的知识,希望对你有一定的参考价值。

  • 缓存
    • 服务器自身(内存)的缓存
      • 利用java程序中的变量
        • 简单
        • 集群环境中多个实例无法共享同步
    • 缓存服务器(一般支持集群、分布式)
      • Redis
      • Memcached
  • Spring中使用注解使用缓存
    • 启动类或者配置类中使用@EnableCaching,必须使用,否则后续注解虽然不报错,但没有使用缓存
    • 使用注解标识方法()
      • @Cacheable,通常用在get方法上
      • @CachePut:运行后会更新/新建缓存中的值,通常用在update方法上
      • @CacheEvict:运行后会删掉缓存中的值,通常用在delete方法上
    • 使用注解标识类(方法上就不用标识了)
      • @CacheConfig:相当于该类下所有的方法的cacheNames都是其中指定的字符串?
    • 参数
      • 标识缓存项,都是用注解中的cacheNames参数和key参数组合起来的:缓存的key是cacheNames::key
        • cacheNames可以是一个字符串数组,可以对应多个缓存的key,每个方法都需要指定cacheNames参数
        • key
          • 通常用SpringEL表达式。
          • 以#开头,内部以.进行分级分隔。
          • 默认按照方法的参数自动生成
          • 可以通过keyGenerator参数自定义生成方式
          • 有时key可以省略,key有默认的机制。如果方法只有一个参数,那么就会用cacheNames和参数值组合成key;如果有多个参数的时候,就会把多个参数组合起来再组合成key。所有要看情况,key有时可以省略,有时不可以。
      • condition可以指定一个条件,用于执行方法前判断是否使用注解的功能
      • unless用于执行方法后,判断是否使用注解提供的功能
      • cacheManager、CacheResolver、keyGenerator
      • @CacheEvict多了两个参数
        • allEntries:值为true则不管key,清除cacheName下所有key的缓存
        • beforeInvocation:值为true,执行方法前清除,默认是执行方法后清除
    • 设置缓存过期
      • 可以和Scheduled Tasks结合,使用CacheEvict注解定时清除缓存
      • 某些缓存服务如Redis,可以通过application.yml配置一个全局的过期时间(默认不过期)
  • 使用Redis
    • 在maven或者gradle中加入依赖
    • 在application.yml中加入配置
    • 可以通过使用RedisTemplate单独设置一些过期时间等
    • 有可能的坑
      • application.yml中其实可以配置key前缀、是否使用key前缀。如果打开了这两个开关,那么有可能导致代码中的cacheNames参数失效,如果两个方法的key相同,那么会导致缓存的key相同导致混乱。根本原因是spring把cacheNames参数也当成了application.yml中所谓的key,所以这两个参数一般不要配

以上是关于Spring Cache的主要内容,如果未能解决你的问题,请参考以下文章

你了解Spring从Spring3到Spring5的变迁吗?

Spring全家桶笔记:Spring+Spring Boot+Spring Cloud+Spring MVC

学习笔记——Spring简介;Spring搭建步骤;Spring的特性;Spring中getBean三种方式;Spring中的标签

Spring--Spring入门

Spring框架--Spring事务管理和Spring事务传播行为

Spring框架--Spring事务管理和Spring事务传播行为