博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
spring缓存
阅读量:5288 次
发布时间:2019-06-14

本文共 4523 字,大约阅读时间需要 15 分钟。

 

 
复制过来时的地址:http://blog.csdn.net/xiaoyu411502/article/details/48901555
标签:
分类:
Spring Boot
(54)
Spring
(16)

Spring Cache

Spring Cache使用方法与Spring对事务管理的配置相似。Spring Cache的核心就是对某个方法进行缓存,其实质就是缓存该方法的返回结果,并把方法参数和结果用键值对的方式存放到缓存中,当再次调用该方法使用相应的参数时,就会直接从缓存里面取出指定的结果进行返回。所以在使用Cache的时候我们要保证我们缓存的方法对于相同的参数要有相同的返回结果。
-----------Spring对Cache的支持有两种方法:
1.基于注解的配置
2.基础XML配置
-----------------------------------------------------通过注解去使用到Cache------------------------------------------
@Cacheable-------使用这个注解的方法在执行后会缓存其返回结果。
@CacheEvict--------使用这个注解的方法在其执行前或执行后移除Spring Cache中的某些元素。
---------------------------------------@Cacheable----------------------------
@Cacheable可以注解在方法上也可以注解在类上。当标记在方法上面时,表示该方法是可以缓存的;如果标记在类上面,则表示该类的所有方法都是可以缓存的。对于一个支持缓存的方法,在执行后,会将其返回结果进行缓存起来,以保证下次同样参数来执行该方法的时候可以从缓存中返回结果,而不需要再次执行此方法。Spring缓存方法的返回值是以键值对进行保存的,值就是返回结果,键的话Spring支持两种策略,一种是默认策略,一种是自定义策略。
注意:一个支持缓存的方法,在对象内部被调用是不会触发缓存功能的。
@Cacheable可以指定三个属性:value、key、condition。
----------------------value:指定Cache的名称
value值是必须指定的,其表示该方法缓存的返回结果是被缓存在哪个Cache上的,对应Cache的名称。其可以是一个Cache也可以使多个Cache(数组);
eg:
[java] 
  1. @Cache"Cx"//Cache是指定在Cx上面的  或者指定多个@Cache(value={"Cx","Cx1"}) public  .....;  
  2. }  

key属性是用来指定Spring缓存方法返回结果时所对应的key值的。该属性支持EL表达式。当我们没有指定key时,Spring会使用默认策略生成key。·
-----------key的自定义策略:
自定义策略是表示我们通过EL表达式来指定我们的key。这里EL表达式可以使用方法参数以及他们对应的属性。使用方法参数时,我们可以使用“#参数名”。
  1. @Cacheable"users")  
  2. public }  

  1. @Cacheable"users")  
  2. public }  

-------1.methodName  当前方法名    #root.methodName
-------2.method       当前方法  #root.method.name
-------3.target   当前被动用对象 #root.target
-------4.targetClass      当前被调用对象Class#root.targetClass
-------5.args    当前方法参数组成的数组 #root.args[0]
-------6.caches    当前被调用方法所使用的Cache #root.caches[0],name
当我们要使用root作为key时,可以不用写root直接@Cache(key="caches[1].name")。因为他默认是使用#root的
-----------------condition:指定发生条件
有时候可能不需要缓存一个方法的所有结果。通过condition可以设置一个条件,其条件值是使用SpringEL表达式来指定的。当为true时进行缓存处理;为false时不进行缓存处理,即每次调用该方法都会执行。
eg:
  1. @Cacheable"users", condition=)  

-----------------------------------------------------@CachePut------------------------------------------
与@Cacheable不同,它虽然也可以声明一个方法支持缓存,但它执行方法前是不会去检查缓存中是否存在之前执行过的结果,而是每次都执行该方法,并将执行结果放入指定缓存中。
 
-----------------------------------------------------@CacheEvict----------------------------------------
@CacheEvict标注在需要清楚缓存元素的方法和类上。@CacheEvict可以指定的属性有value、key、condition、allEntries和beforeInvocation。value表示清除缓存作用在哪个Cache上;key是表示需要清除的是哪个key。
--------------allEntries是表示是否需要清除缓存中所有的元素。
--------------beforeInvocation
清除操作默认是在方法成功执行之后触发的。使用beforeInvocation可以改变触发清除操作的时间,当我们设置为true时,Spring会在调用该方法之前进行缓存的清除。
------------------------------------------------------@Caching-------------------------------------------
  1. @Caching@Cacheable"users"@CacheEvict"cache2"@CacheEvict"cache3"true>    </span>  

-------------------------------------------------------自定义注解-----------------------------------------
  1. @Target @Retention @Cacheable"users" public MyCacheable {  
  2. }  

----------------------------------------------------------------------------------------------------------------------------------------------
--------------------------配置Spring对Cache的支持
声明对Cache的支持
1.基于注解
配置Spring对注解Cache的支持,我们需要在Spring配置文件中添加Cache命名空间,然后通过<cache:anotation-driven/>
就可以启动Spring对注解Cache的支持。
其中<cache:anotation-driven/>有一个mode属性,可以选择值proxy和aspectj。默认使用proxy。当mode为proxy时,只有缓存方法在外部被调用的时候才会生效。这也就意味着如果一个缓存方法在一个对象的内部被调用SpringCache是不会发生作用的。而mode为aspectj时,就不会有这种问题了。另外使用proxy的时候,只有public方法上的@Cacheable才会发生作用。如果想非public上的方法也可以使用那么就把mode改成aspectj。
注意:当我们mode使用aspectj和proxy-target-class为true时,定义在接口上的Cache注解是无法被识别的。<cache:cache-driven/>只会去寻找定义在同一个ApplicationContext下的@Cacheable等缓存注解。
2.基于XML配置
Spring还支持使用XML文件来配置,方式和配置事务管理类似。
  1. <cache:advice id= cache-manager=>  
  2. >  
  3.  key=/>  
  4.  key=/>  
  5.  all-entries=/>  
  6.    </cache:advice>  

 
然后在配置aop:config指定定义好的advice作用到那些地方(pointcut)
  1. <aop:config proxy-target-=>  
  2.  pointcut=    </aop:config>  

3.配置CacheManager
CacheManager是Spring定义的一个用来管理Cache的接口。Spring自身提供了两种,一种是基于JAVA API的ConcurrentMap,另一种是基于第三方Cache实现--Ehcache。
---------------------基于ConcurrentMap的配置
  1. <bean id= =>  
  2. >  
  3. = p:name=/>  
  4.    </bean>  

---------------------基于Ehcache的配置
  1. <bean id= = p:cache-manager-ref=/>  
  2.  = p:config-location=/>  

---------------------------------------------------------键的生成策略-----------------------------------------------------------
键的生成策略有两种,一种是默认策略,一种是自定义策略。
----------------------------默认策略:
默认的key是通过KeyGenerator生成的,其默认策略如下:
1.如果方法没有参数,则使用0作为key;
2.如果只有一个参数的话则使用该参数作为key;
3.如果参数多于一个则使用所有参数的hashcode作为key;
----------------------------自定义策略:
自定义策略是指我们通过Spring的EL表达式来指定我们的key。这里的EL表达式可以使用参数以及它们对应的属性。使用方法参数时我们可以直接使用“#参数名”或者“#p参数index”。

转载于:https://www.cnblogs.com/c-cccc/p/5938543.html

你可能感兴趣的文章
Jmeter发送post请求报错Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported...
查看>>
POI3.8内存中限制行数为100问题记录
查看>>
Linux搭建服务
查看>>
Solr:CVE-2019-0193复现
查看>>
Linux常用命令
查看>>
[JZOJ6299] 2019.08.12【NOIP提高组A】工厂
查看>>
5432. 【NOIP2017提高A组集训10.28】三元组
查看>>
[JZOJ6355] 【NOIP2019模拟】普 24/100
查看>>
[JZOJ6353] 【NOIP2019模拟】给
查看>>
[JZOJ4330] 【清华集训模拟】几何题
查看>>
[JZOJ6341] 【NOIP2019模拟2019.9.4】C
查看>>
[JZOJ4331] 【清华集训模拟】树
查看>>
[JZOJ6272] 2019.8.4【NOIP提高组A】整除
查看>>
[JZOJ1900] 【2010集训队出题】矩阵
查看>>
[JZOJ1901] 【2010集训队出题】光棱坦克
查看>>
[JZOJ3424] 【NOIP2013模拟】粉刷匠
查看>>
[JZOJ6340] 【NOIP2019模拟2019.9.4】B
查看>>
[JZOJ2865]【集训队互测 2012】Attack
查看>>
[JZOJ6271] 2019.8.4【NOIP提高组A】锻造
查看>>
[JZOJ6278] 2019.8.5【NOIP提高组A】跳房子
查看>>