ehcache 二级查询缓存
MyBatis 的特长是 SQL 操作,缓存数据管理不是其特长,为了提高缓存的性能,MyBatis 允许使用第三方缓存产品。ehCache 就是其中的一种。
项目:MyBatis_SecondLevel_ehCache。在上一个项目的基础上进行修改即可。
注意,使用 ehcache 二级缓存,实体类无需实现序列化接口。
- 导入 Jar 包
这里需要两个 Jar 包:一个是 ehcache 的核心 Jar 包,一个是与 MyBatis 整合的插件 Jar 包。他们可以从https://github.com/mybatis/ehcache-cache/releases下载。
解压缩文件,获取到它们。其中 lib 下的是 ehcache 的核心 Jar 包。
- 添加 ehcache.xml
解压EHCache的核心Jar包ehcache-core-2.6.8.jar,将其中的一个配置文件
ehcache- failsafe.xml直接放到项目的src目录下,并更名为ehcache.xml。
(1)<diskStore/>标签
指定一个文件目录,当内存空间不够,需要将二级缓存中数据写到硬盘上时,会写到这个指定目录中。其值一般为 java.io.tmpdi,表示当前系统的默认文件临时目录。
当前系统的默认文件临时目录,可以通过 System.property() 方法查看:
(2)<defaultCache/>标签
设定缓存的默认属性数据:
① maxElementsInMemory:指定该内存缓存区可以存放缓存对象的最多个数。
② eternal:设定缓存对象是否不会过期。若设为 true,表示对象永远不会过期,此时会忽略 timeToldleSeconds 与 timeToLiveSeconds 属性。默认值为 false。
③ timeToldleSeconds:设定允许对象处于空闲状态的最长时间,以秒为单位。当对象自从最近一次被访问后,若处于空闲状态的时间超过了 timeToldleSeconds 设定的值,这个对象就会过期。当对象过期,EHCache 就会将它从缓存中清除。设置值为0,则对象可以无限期地处于空闲状态。
④ timeToLiveSeconds:设定对象允许存在于缓存中的最长时间,以秒为单位。当对象自从被存放到缓存后,若处于缓存中的时间超过了 timeToLiveSeconds 设定的值,这个对象就会过期。当对象过期,EHCache 就会将它从缓存中清除。设置值为0,则对象可以无限期地存在于缓存中。注意,只有 timeToLiveSeconds ≥ timeToldleSeconds,才有意义。
⑤ overflowToDisk:设定为 true,表示当缓存对象达到了 maxElementsInMemory 界限,会将溢出的对象写到<diskStore>元素指定的硬盘日录缓存中。
⑥ maxElementsOnDisk:指定硬盘缓存区可以存放缓存对象的最多个数。
⑦ diskPersistent:指定当程序结束时,硬盘缓存区中的缓存对象是否做持久化。
⑧ diskExpiryThreadIntervalSeconds:指定硬盘中缓存对象的失效时间间隔。
⑨ memoryStoreEvictionPolicy: 如果内存缓存区超过限制,选择移向硬盘缓存区中的
对象时使用的策略。支持三种策略:
●FIFO:
First In First Out,先进先出
●LFU:
Less Frequently Used,最少使用
●LRU:
Least Recently Used,最近最少使用
启用 ehcache 缓存机制
在映射文件的 mapper 中的<cache/>中通过 type 指定缓存机制为 Ehcache 缓存。默认为 myBatis 内置的二级缓存 org.apache.ibatis.cache.impl.PerpetualCache。
该类在 mybatis-ehcache 的 jar 包中可以找到。
ehcache 在不同 mapper 中的个性化设置
在 ehcache.xml 中设置的属性值,会对该项目中所有使用 ehcache 缓存机制的缓存区域起作用。一个项目中可以有多个 mapper,不同的 mapper 有不同的缓存区域。对于不同缓存区域也可进行专门针对于当前区域的个性化设置,可通过指定不同 mapper 的<cache>属性值来设置。
<cache>属性值的优先级高于ehcache.xml中的属性值。