hibernate,二级缓存的设置。
二级缓存(SessionFactory缓存)——外部插件(EHCache)。
原理:查询的数据,会自动存放在SessionFactory中,只要SessionFactory不关闭,数据始终存在。(Session每次获取数据时都会到二级缓冲中查找)。
配置二级缓冲步骤:
- 导入EHCache的jar包。
- 在hibernate.cfg.xml中配置二级缓冲(启用二级缓存)。
- 在src目录下,添加一个配置文件(ehcache.xml)用来配置缓存的对象。
- 在xxxx.hbm.xml中添加<cache>标签用来表示是否缓存该对象。
注意:HQL语句默认不会执行缓存查询;如果需要添加缓存查询功能:
- 在hibernate.cfg.xml中添加属性:cache.use_query_cache = true;
- 在Query对象中设置setCacheable(true).list();
ehcache.xml文件 <?xml version="1.0" encoding="UTF-8"?> <ehcache> <!--timeToIdleSeconds 当缓存闲置n秒后销毁 --> <!--timeToLiveSeconds 当缓存存活n秒后销毁 --> <!-- 缓存配置 name:缓存名称。 maxElementsInMemory:缓存最大个数。 eternal:对象是否永久有效,一但设置了,timeout将不起作用。 timeToIdleSeconds:设置对象在失效前的允许闲置时间(单位:秒)。仅当eternal=false对象不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。 timeToLiveSeconds:设置对象在失效前允许存活时间(单位:秒)。最大时间介于创建时间和失效时间之间。仅当eternal=false对象不是永久有效时使用,默认是0.,也就是对象存活时间无穷大。 overflowToDisk:当内存中对象数量达到maxElementsInMemory时,Ehcache将会对象写到磁盘中。 diskSpoolBufferSizeMB:这个参数设置DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区。 maxElementsOnDisk:硬盘最大缓存个数。 diskPersistent:是否缓存虚拟机重启期数据 Whether the disk store persists between restarts of the Virtual Machine. The default value is false. diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒。 memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。默认策略是LRU(最近最少使用)。你可以设置为FIFO(先进先出)或是LFU(较少使用)。 clearOnFlush:内存数量最大时是否清除。 --> <diskStore path="java.io.tmpdir" /> <defaultCache maxElementsInMemory="500" eternal="false" timeToIdleSeconds="300" timeToLiveSeconds="1200" overflowToDisk="true" /> <cache name="com.zuxia.model.Dept" maxElementsInMemory="100" eternal="false" timeToIdleSeconds="300" timeToLiveSeconds="1200" overflowToDisk="true" /> <cache name="com.zuxia.model.Dept.emps" maxElementsInMemory="100" eternal="false" timeToIdleSeconds="300" timeToLiveSeconds="1200" overflowToDisk="true" /> </ehcache>

浙公网安备 33010602011771号