mybatis二级缓存
- 1.mybatis的一级缓存sqlsession
- 2.二级缓存指的同一命名空间(namespace) mapper
mybatis默认二级缓存未开启。内置是支持二级缓存的。但是由于本身是数据库管理组件,所以缓存并不好用,还要用第三方。典型ehcache。
二级缓存的常见算法。
缓存算法有:
LRU(Least Recently Used):这种算法是在每个对象中维护一个访问的时间变量,每次访问后,时间都会更新,当新的对象需要存放到缓存时,替换那个按时间排序最后的对象。
LFU(Least Frequently Used):这种算法是每个对象记录了对象访问的次数(即命中率),当新的对象需要存放到缓存时,替换那个访问次数最少的对象。
FIFO(First In First Out):这种算法是将缓存中的对象存放成一个数组,当新的对象需要存放到内存中是,替换最先存放到缓存的对象。
mybatis中开启二级缓存
1.对象要实现序列化接口Serializable
2.在mapper映射文件添加
<!-- 开启二级缓存 -->
<cache/>
3.在mabaits配置文件中开启二级缓存
<!-- 设置启动二级缓存 -->
<setting name="cacheEnabled" value="true"/>
与ehcache集成
1.导入jar包
2.生成ehcache.xml配置文件
3.setting中开启二级缓存
4.在mapper文件中指定cache类型为ehcache
<!-- 开启二级缓存 -->
<cache type="org.mybatis.caches.ehcache.EhcacheCache" ></cache>