当前位置: 代码迷 >> Web前端 >> ehcache配备
  详细解决方案

ehcache配备

热度:160   发布时间:2012-11-22 00:16:41.0
ehcache配置
参考博文地址:http://blog.csdn.net/hnzhangshilong/article/details/6689675


使用ehcache配置hibernate缓存策略
实体bean注解配置:
@Entity
@Table(name = "consumer", catalog = "cdr_busines")// 对应cdr_busines数据库中的consumer表
@org.hibernate.annotations.Cache
(usage=CacheConcurrencyStrategy.READ_WRITE)// 读写缓存

这里需要注意,当实体类中包含集合的时候,需要在集合的get方法上面添加@Cache(usage=CacheConcurrencyStrategy.READ_WRITE)注解,关联的也得添加,要不然也不能缓存此对象以及对象集合



spring配置hibernateproperties文件中的配置信息:
<prop key="hibernate.cache.use_second_level_cache">true</prop>
                <prop key="hibernate.cache.provider_class">net.sf.ehcache.hibernate.EhCacheProvider</prop>
                <prop key="hibernate.cache.use_query_cache">true</prop>
                <prop key="hibernate.cache.provider_configuration_file_resource_path">ehcache.xml</prop>


以上配置就可以实现ehcache的缓存
但是不缓存集合结果,如果需要缓存集合结果需要在session,createQuery(hql)的返回值org.hibernate.Query设置.setCacheable(true)来开启查询集合缓存

ehcache.xml
<?xml version="1.0" encoding="UTF-8"?>
<ehcache name="CdrCache">
需要配置diskStore
  <diskStore path="java.io.tmpdir"/>
  <defaultCache
      maxElementsInMemory="10000"
      eternal="false"
      timeToIdleSeconds="120"
      timeToLiveSeconds="120"
      overflowToDisk="true"
      diskPersistent="false"
      diskExpiryThreadIntervalSeconds="120"
      memoryStoreEvictionPolicy="LRU"/>
  <cache name="colors"
         maxElementsInMemory="100"
         eternal="false"
         timeToIdleSeconds="120"
         timeToLiveSeconds="0"
         memoryStoreEvictionPolicy="LFU">
  </cache>
</ehcache>

<!--
? name:Cache的唯一标识
? maxElementsInMemory:内存中最大缓存对象数。
? maxElementsOnDisk:磁盘中最大缓存对象数,若是0表示无穷大。
? eternal:Element是否永久有效,一但设置了,timeout将不起作用。
? overflowToDisk:配置此属性,当内存中Element数量达到maxElementsInMemory时,Ehcache将会Element写到磁盘中。
? timeToIdleSeconds:设置Element在失效前的允许闲置时间。仅当element不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。
? timeToLiveSeconds:设置Element在失效前允许存活时间。最大时间介于创建时间和失效时间之间。仅当element不是永久有效时使用,默认是0.,也就是element存活时间无穷大。
? diskPersistent:是否缓存虚拟机重启期数据。(这个虚拟机是指什么虚拟机一直没看明白是什么,有高人还希望能指点一二)。
? diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒。
? diskSpoolBufferSizeMB:这个参数设置DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区。
? memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。默认策略是LRU(最近最少使用)。你可以设置为FIFO(先进先出)或是LFU(较少使用)。这里比较遗憾,Ehcache并没有提供一个用户定制策略的接口,仅仅支持三种指定策略,感觉做的不够理想。
-->

地址: http://jie66989.iteye.com/blog/1699656
  相关解决方案