redis的Cacheable注解使用及说明
作者:我曾遇到一束光
文章介绍了如何在Java应用中使用Spring的@Cacheable注解进行缓存配置,包括注解的使用、key的生成方式、触发条件(condition)和排除条件(unless)的设置,并强调了缓存的持久性和清除机制
引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.1.1.RELEASE</version>
</dependency>
导入的使用较多的2.1.1依赖,版本过高可能会导致找不到加载类.
添加注解
主类中中加入注解@EnableCaching,
然后就可以在方法或者类上边使用@Cacheable
- @Cacheable 的作用 主要针对方法配置,能够根据方法的请求参数对其结果进行缓存
- @Cacheable 作用和配置方法
value
- 用来存放我们要保存的key的集合。类型为标准的String
key
- 我们实际要保存到redis的key,可以增加参数,以方法的参数或者属性。类型为String,但是需要做处理。 需要将我们自定义的字符串以"’"括起来再与参数进行拼接。
- 如果需要用到方法中的参数,可以用 #+参数名直接获 取。
- 如果需要用到方法中参数的属性,可以向Java对象一样,用 . 获取。如 #channel.name,如果此注解使用在方法上,可以根据方法设置key,如:#root.method。

keyGenerator
@Component("myKeyGenerator")
public class MyKeyGenerator implements KeyGenerator {
@Override
public Object generate(Object target, Method method, Object... params) {
return "method.getName()" + "["+ Arrays.asList(params).toString()+"]";
}
}
@Cacheable(value ="provinceCount",keyGenerator = "myKeyGenerator",sync = true)
condition
- 触发条件。
- 这个参数是规定这个缓存触发的条件拼接。
- 如 condition="#channel != null",就是在channel不 为null的时候触发。
unless
- 排除条件。
- 这个参数是规定这个缓存在什么时候不触发。
- 如 unless="#result == null",就是在结果为null的 时候触发。
注意点
使用@Cacheable生成的缓存是不会清除的,同时当redis中已经存在相同的key时,@Cacheable默认不生成缓存
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
