引子
我现在负责项目中,数据计算量比较大,有强烈的缓存需求。但是无奈,我司的Redis在集群封装后,不支持“批量操作”的命令。所以,Spring Cache 框架就用不了了。我只能自己使用AOP去实现一套类似的逻辑。
问题描述
在项目中,我自定义了一个注解:
@Documented
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface Expire {
/**
* 需要过期的Key,支持 SPEL表达式
*/
String key() default "";
/**
* 是否使当前缓存下所有key失效
*/
boolean allEntries() default false;
}
上面的@Expire 使用类似@CacheEvict,可以指定一个缓存下的所有KEY都过期,或者 指定一个KEY过期。
现在产品有这样一个需求,要求能够指定KEY使对应缓存过期。而在我们项目中,KEY是由一个方法统一控制的,所以,这里就要求 @Expire 注解在使用key 属性的时候,能够支持SPEL表达式解析。
@Service
public class CacheToolService {
/**
* 根据 方法名,参数,组装出 缓存的 key
*
* @param method 方法
* @param args