一.Ehcache简介
EhCache是一个纯Java的进程内缓存框架,具备以下特色:
1. 快速简单,很是容易和应用集成。
2.支持多种缓存策略 。
3. 缓存数据有两级:内存和磁盘,所以无需担忧容量问题 。
4. 缓存数据会在虚拟机重启的过程当中写入磁盘 。
5. 能够经过RMI、可插入API等方式进行分布式缓存。
6. 具备缓存和缓存管理器的侦听接口 。
7. 支持多缓存管理器实例,以及一个实例的多个缓存区域 等特色。
二.Ehcache配置的相关参数
Ehcache的配置很灵活,官方提供的配置方式有好几种,你能够经过声明配置、在xml中配置、在程序里配置或者调用构造方法时传入不一样的参数。下面以最经常使用的XML配置为例说下配置的相关参数的意义,ehcache.xml是最多见的一个文件,ehcache通常会经过CacheManager从classpath加载该文件完成Cache的实例化。
1.ehcache.xml中的配置信息
ehcache.xml片断:java
<ehcache> <diskStore path="java.io.tmpdir"/> <defaultCache name="name" maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" maxElementsOnDisk="10000000" diskPersistent="false" diskExpiryThreadIntervalSeconds="120" memoryStoreEvictionPolicy="LRU" /> </ehcache>
2.Cache中经常使用参数的具体意义
(1)name:Cache的惟一标识。
(2)maxElementsInMemory:内存中最大缓存对象数。
(3)eternal:Element是否永久有效,一旦设置true,timeout将不起做用。
(4)timeToIdleSeconds:设置Element在失效前的容许闲置时间。仅当element不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。
(5)timeToLiveSeconds:设置Element在失效前容许存活时间。最大时间介于建立时间和失效时间之间。仅当element不是永久有效时使用,默认是0.,也就是element存活时间无穷大。
(6)overflowToDisk:配置此属性,当内存中Element数量达到maxElementsInMemory时,Ehcache将会Element写到磁盘中。
(7)maxElementsOnDisk:磁盘中最大缓存对象数,如果0表示无穷大。
(8) memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理缓存中的内容。默认策略是LRU(最近最少使用),你也能够设置为FIFO(先进先出)或是LFU(较少使用)
三.Spring和Ehcache的集成
1.ehcache.xmlspring
2.beans.xml的配置缓存
<bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean"> <property name="configLocation"> <value>classpath:ehcache.xml</value> </property> </bean> <bean id="levelOneCache" class="org.springframework.cache.ehcache.EhCacheFactoryBean"> <property name="cacheManager"> <ref local="cacheManager" /> </property> <property name="cacheName"> <value>configCache</value> </property> </bean>
3.测试类app
输出以下:框架
cacheObject[name:test],没法从缓存中取到 cacheObject[name:test],从缓存中取到 cacheObject[name:test],从缓存中取到 cacheObject[name:test],从缓存中取到 cacheObject[name:test],从缓存中取到
四.利用Spring AOP和Ehcache实现线程级方法缓存
在复杂的业务逻辑或在一次计算中需屡次调用同一个DAO或远程服务,在这种状况下,都可对计算结果缓存起来,不但能够减小了没必要要的调用次数,还同时能够提升系统运算性能。下面以缓存一个service为例说明一下其用法。
1.TestService接口分布式
2.TestServiceImpl实现类性能
3.拦截器的实现测试
4.Bean的配置this
5.测试方法spa
其输出结果以下: