Spring Cache
Posted wyp1988
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring Cache相关的知识,希望对你有一定的参考价值。
- 缓存
- 服务器自身(内存)的缓存
- 利用java程序中的变量
- 简单
- 集群环境中多个实例无法共享同步
- 利用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,执行方法前清除,默认是执行方法后清除
- 标识缓存项,都是用注解中的cacheNames参数和key参数组合起来的:缓存的key是cacheNames::key
- 设置缓存过期
- 可以和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中的标签