mybatis缓存机制的学习
(一 )一级缓存
一级缓存缓存的范围为SqlSession,mybatis自动开启,无需设置。
1、什么时候不走缓存
a、查询数据库使用的不是同一个SqlSession对象。
b、查询的语句或者条件不同。
2、什么时候一级缓存失效
a、在查询数据库前使用SqlSession对象的clearCache方法和close方法。
b、执行了任意的select、update、delete语句。
以上行为会清空当前SqlSession对象的一级缓存。
(二 )二级缓存
使用二级缓存需要具备以下几个条件:
1、<setting name="cacheEnabled" value="true"> 全局性地开启或关闭所有映射器配置文件中已配置的任何缓存。默认就是true,无需设置。
2、在需要使用二级缓存的SqlMapper.xml文件中添加配置:<cache />
3、使用二级缓存的实体类对象必须是可序列化的,也就是必须实现java.io.Serializable接口
4、SqlSession对象关闭或提交之后,一级缓存中的数据才会被写入到二级缓存当中。此时二级缓存才可用。
二级缓存区域是以mapper为单位划分的,在mapper的同一个namespace中,如果有其它insert、update、delete操作数据后都会刷新缓存,如果不执行刷新缓存会出现脏读。
通过mybatis发起的查询,作用顺序为:二级缓存->一级缓存->数据库 ,其中任何一个环节查到不为空的数据,都将直接返回结果
二级缓存局限性
mybatis二级缓存对细粒度的数据级别的缓存实现不好,对同时缓存较多条数据的缓存,比如如下需求:对商品信息进行缓存,由于商品信息查询访问量大,但是要求用户每次都能查询最新的商品信息,此时如果使用mybatis的二级缓存就无法实现当一个商品变化时只刷新该商品的缓存信息而不刷新其它商品的信息,因为mybaits的二级缓存区域以mapper为单位划分,当一个商品信息变化会将所有商品信息的缓存数据全部清空。
二级缓存的相关配置:
- eviction:指定从缓存中移除某个对象的淘汰算法。默认采用LRU策略。
-
- LRU:Least Recently Used。最近最少使用。优先淘汰在间隔时间内使用频率最低的对象。(其实还有一种淘汰算法LFU,最不常用。)
- FIFO:First In First Out。一种先进先出的数据缓存器。先进入二级缓存的对象最先被淘汰。
- SOFT:软引用。淘汰软引用指向的对象。具体算法和JVM的垃圾回收算法有关。
- WEAK:弱引用。淘汰弱引用指向的对象。具体算法和JVM的垃圾回收算法有关。
- flushInterval:
-
- 二级缓存的刷新时间间隔。单位毫秒。如果没有设置。就代表不刷新缓存,只要内存足够大,一直会向二级缓存中缓存数据。除非执行了增删改。
- readOnly:
-
- true:多条相同的sql语句执行之后返回的对象是共享的同一个。性能好。但是多线程并发可能会存在安全问题。
- false:多条相同的sql语句执行之后返回的对象是副本,调用了clone方法。性能一般。但安全。
- size:
-
- 设置二级缓存中最多可存储的java对象数量。默认值1024
参考文章:
MyBatis|缓存机制 - 简书mybatis的缓存机制(一级缓存二级缓存和刷新缓存)和mybatis整合ehcache_双斜杠少年的博客-CSDN博客