mybatis提供了一个cache接口,如果要实现自己的缓存逻辑,实现cache接口开发即可。
mybatis和ehcache整合,mybatis和ehcache整合包中提供了一个cache接口的实现类。
1.4.3 第一步加入ehcache包
1.4.4 整合ehcache
配置mapper中cache中的type为ehcache对cache接口的实现类型。
<mappernamespace='cn.hpu.mybatis.mapper.UserMapper'>
<!-- 开启本mappernamespace下的二级缓存
type:指定cache接口实现类,mybatis默认使用PerpetualCache
要和eache整合,需要配置type为ehcahe实现cache接口的类型
-->
<cachetype='org.mybatis.caches.ehcache.EhcacheCache'>
</cache>
可以根据需求调整缓存参数:
<cachetype='org.mybatis.caches.ehcache.EhcacheCache'>
<propertyname='timeToIdleSeconds'value='3600'/>
<propertyname='timeToLiveSeconds'value='3600'/>
<!-- 同ehcache参数maxElementsInMemory-->
<propertyname='maxEntriesLocalHeap'value='1000'/>
<!-- 同ehcache参数maxElementsOnDisk -->
<propertyname='maxEntriesLocalDisk'value='10000000'/>
<propertyname='memoryStoreEvictionPolicy'value='LRU'/>
</cache>
1.4.5 加入ehcache的配置文件
在classpath下配置ehcache.xml
<ehcachexmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'
xsi:noNamespaceSchemaLocation='../config/ehcache.xsd'>
<diskStorepath='F:\develop\ehcache'/>
<defaultCache
maxElementsInMemory='1000'
maxElementsOnDisk='10000000'
eternal='false'
overflowToDisk='false'
timeToIdleSeconds='120'
timeToLiveSeconds='120'
diskExpiryThreadIntervalSeconds='120'
memoryStoreEvictionPolicy='LRU'>
</defaultCache>
</ehcache>
属性说明:
diskStore:指定数据在磁盘中的存储位置。
defaultCache:当借助CacheManager.add('demoCache')创建Cache时,EhCache便会采用<defalutCache/>指定的的管理策略
以下属性是必须的:
maxElementsInMemory - 在内存中缓存的element的最大数目
maxElementsOnDisk - 在磁盘上缓存的element的最大数目,若是0表示无穷大
eternal - 设定缓存的elements是否永远不过期。如果为true,则缓存的数据始终有效,如果为false那么还要根据timeToIdleSeconds,timeToLiveSeconds判断
overflowToDisk- 设定当内存缓存溢出的时候是否将过期的element缓存到磁盘上
以下属性是可选的:
timeToIdleSeconds - 当缓存在EhCache中的数据前后两次访问的时间超过timeToIdleSeconds的属性取值时,这些数据便会删除,默认值是0,也就是可闲置时间无穷大
timeToLiveSeconds - 缓存element的有效生命期,默认是0.,也就是element存活时间无穷大
diskSpoolBufferSizeMB 这个参数设置DiskStore(磁盘缓存)的缓存区大小.默认是30MB.每个Cache都应该有自己的一个缓冲区.
diskPersistent在VM重启的时候是否启用磁盘保存EhCache中的数据,默认是false。
diskExpiryThreadIntervalSeconds - 磁盘缓存的清理线程运行间隔,默认是120秒。每个120s,相应的线程会进行一次EhCache中数据的清理工作
memoryStoreEvictionPolicy - 当内存缓存达到最大,有新的element加入的时候,移除缓存中element的策略。默认是LRU(最近最少使用),可选的有LFU(最不常使用)和FIFO(先进先出)
1.5 二级应用场景
对于访问多的查询请求且用户对查询结果实时性要求不高,此时可采用mybatis二级缓存技术降低数据库访问量,提高访问速度,业务场景比如:耗时较高的统计分析sql、电话账单查询sql等。
实现方法如下:通过设置刷新间隔时间,由mybatis每隔一段时间自动清空缓存,根据数据变化频率设置缓存刷新间隔flushInterval,比如设置为30分钟、60分钟、24小时等,根据需求而定。
1.6 二级缓存局限性
mybatis二级缓存对细粒度的数据级别的缓存实现不好,对同时缓存较多条数据的缓存,比如如下需求:对商品信息进行缓存,由于商品信息查询访问量大,但是要求用户每次都能查询最新的商品信息,此时如果使用mybatis的二级缓存就无法实现当一个商品变化时只刷新该商品的缓存信息而不刷新其它商品的信息,因为mybaits的二级缓存区域以mapper为单位划分,当一个商品信息变化会将所有商品信息的缓存数据全部清空。解决此类问题需要在业务层根据需求对数据有针对性缓存。需要使用三级缓存