欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用@CacheEvict清除指定下所有缓存

程序员文章站 2022-03-04 15:29:21
目录@cacheevict清除指定下所有缓存@cacheable 缓存 @cacheput:缓存更新 @cacheevict:缓存删除@cacheable 缓存@cacheput:缓存更新@cache...

@cacheevict清除指定下所有缓存

@cacheevict(cachenames = "parts:grid",allentries = true) 

此注解会清除part:grid下所有缓存

@cacheevict要求指定一个或多个缓存,使之都受影响。此外,还提供了一个额外的参数allentries 。表示是否需要清除缓存中的所有元素。默认为false,表示不需要。

当指定了allentries为true时,spring cache将忽略指定的key。有的时候我们需要cache一下清除所有的元素。

@cacheable 缓存 @cacheput:缓存更新 @cacheevict:缓存删除

@cacheable 缓存

说明:在支持spring cache的环境下,对于使用@cacheable标注的方法,spring在每次执行前都会检查cache中是否存在相同key的缓存元素,如果存在就不再执行该方法,而是直接从缓存中获取结果进行返回,否则才会执行并将返回结果存入指定的缓存中。

// @since 3.1  可以标注在方法上、类上  下同
@target({elementtype.method, elementtype.type})
@retention(retentionpolicy.runtime)
@inherited
@documented
public @interface cacheable {
    // 缓存名称  可以写多个,key的真正组成,以cachename为前缀,多个就会有多个key产生
    @aliasfor("cachenames")
    string[] value() default {};
    @aliasfor("value")
    string[] cachenames() default {};
    // 支持写spel,切可以使用#root,#参数名”或者“#p参数index”
    //详情去 https://blog.csdn.net/dalong_bamboo/article/details/103844076
    string key() default "";
    // mutually exclusive:它和key属性互相排斥。请只使用一个,直接写bean的名字就可以
    string keygenerator() default "";
   //用于选择使用哪个cachemanager
    string cachemanager() default "";
    //用户定义如何处理缓存,实现 org.springframework.cache.interceptor.cacheresolver接口
    string cacheresolver() default "";
    // 表示在哪种情况下才缓存结果,可使用spel,可以使用#root。  只有true时,才会作用在这个方法上
    string condition() default "";
    // 表示在哪种情况下不缓存结果,可以写spel #root,并且可以使用#result拿到方法返回值    经典值#result == null
    string unless() default "";
    
    // true:表示强制同步执行。(若多个线程试图为**同一个键**加载值,以同步的方式来进行目标方法的调用)
    // 同步的好处是:后一个线程会读取到前一个缓存的缓存数据,不用再查库了~~~ 
    // 默认是false,不开启同步one by one的
    // @since 4.3  注意是sync而不是async
    // 它的解析依赖于spring4.3提供的cache.get(object key, callable<t> valueloader);方法
    boolean sync() default false;
}

@cacheput:缓存更新

说明:@cacheput也可以声明一个方法支持缓存功能。

与@cacheable不同的是使用@cacheput标注的方法在执行前不会去检查缓存中是否存在之前执行过的结果,而是每次都会执行该方法,并将执行结果以键值对的形式存入指定的缓存中。

@target({elementtype.method, elementtype.type})
@retention(retentionpolicy.runtime)
@inherited
@documented
public @interface cacheable {
 @aliasfor("cachenames")
 string[] value() default {};
 @aliasfor("value")
 string[] cachenames() default {};
 // 注意:它和上面区别是。此处key它还能使用#result
 string key() default "";
 string keygenerator() default "";
 string cachemanager() default "";
 string cacheresolver() default "";
 string condition() default "";
 string unless() default "";
}

@cacheevict:缓存删除

说明:@cacheevict是用来标注在需要清除缓存元素的方法或类上的。当标记在一个类上时表示其中所有的方法的执行都会触发缓存的清除操作。

@cacheevict可以指定的属性有value、key、condition、allentries和beforeinvocation。其中value、key和condition的语义与@cacheable对应的属性类似。

即value表示清除操作是发生在哪些cache上的(对应cache的名称);key表示需要清除的是哪个key,如未指定则会使用默认策略生成的key;condition表示清除操作发生的条件。

下面我们来介绍一下新出现的两个属性allentries和beforeinvocation。

allentries属性,allentries是boolean类型,表示是否需要清除缓存中的所有元素。

默认为false,表示不需要。当指定了allentries为true时,spring cache将忽略指定的key。

有的时候我们需要cache一下清除所有的元素,这比一个一个清除元素更有效率。

@target({elementtype.method, elementtype.type})
@retention(retentionpolicy.runtime)
@inherited
@documented
public @interface cacheable {
 @aliasfor("cachenames")
 string[] value() default {};
 @aliasfor("value")
 string[] cachenames() default {};
 // 它也能使用#result
 string key() default "";
 string keygenerator() default "";
 string cachemanager() default "";
 string cacheresolver() default "";
 string condition() default "";
 // 是否把上面cachenames指定的所有的缓存都清除掉,默认false
 boolean allentries() default false;
 // 是否让清理缓存动作在目标方法之前执行,默认是false(在目标方法之后执行)
 // 注意:若在之后执行的话,目标方法一旦抛出异常了,那缓存就清理不掉了~~~~
 boolean beforeinvocation() default false;
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。