深入理解Mybatis缓存
2016-03-09 00:00
267 查看
首先来了解下官方文档对Mybatis缓存的介绍:
默认情况下是没有开启缓存的,除了局部的 session 缓存,可以增强变现而且处理循环 依赖也是必须的。要开启二级缓存,你需要在你的 SQL 映射文件中添加一行:
字面上看就是这样。这个简单语句的效果如下:
映射语句文件中的所有 select 语句将会被缓存。
映射语句文件中的所有 insert,update 和 delete 语句会刷新缓存。
缓存会使用 Least Recently Used(LRU,最近最少使用的)算法来收回。
根据时间表(比如 no Flush Interval,没有刷新间隔), 缓存不会以任何时间顺序 来刷新。
缓存会存储列表集合或对象(无论查询方法返回什么)的 1024 个引用。
缓存会被视为是 read/write(可读/可写)的缓存,意味着对象检索不是共享的,而 且可以安全地被调用者修改,而不干扰其他调用者或线程所做的潜在修改。
所有的这些属性都可以通过缓存元素的属性来修改。比如:
这个更高级的配置创建了一个 FIFO 缓存,并每隔 60 秒刷新,存数结果对象或列表的 512 个引用,而且返回的对象被认为是只读的,因此在不同线程中的调用者之间修改它们会 导致冲突。
可用的收回策略有:
LRU – 最近最少使用的:移除最长时间不被使用的对象。
FIFO – 先进先出:按对象进入缓存的顺序来移除它们。
SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象。
WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对
3ff0
象。
默认的是 LRU。
flushInterval(刷新间隔)可以被设置为任意的正整数,而且它们代表一个合理的毫秒 形式的时间段。默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新。
size(引用数目)可以被设置为任意正整数,要记住你缓存的对象数目和你运行环境的 可用内存资源数目。默认值是 1024。
readOnly(只读)属性可以被设置为 true 或 false。只读的缓存会给所有调用者返回缓 存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。可读写的缓存 会返回缓存对象的拷贝(通过序列化) 。这会慢一些,但是安全,因此默认是 false。
现在来通过源码看下他具体的实现逻辑:
org.apache.ibatis.session.Configuration.class
![](http://static.oschina.net/uploads/space/2016/0309/151622_NUnS_817621.png)
cacheEnabled是一个全局的Cache开关,是在mybatis-config.xml里配置的,配置方法为
其实这样的配置可以省略,因为mybatis默认是true。
org.apache.ibatis.builder.xml.XMLConfigBuilder.class
![](http://static.oschina.net/uploads/space/2016/0309/162516_O8Cd_817621.png)
CachingExecutor其实是一个代理对象,他代理了上一步创建的BatchExecutor或ReuseExecutor或SimpleExecutor。
当我们执行session的query方法时,他会转给我们的CachingExecutor的query
org.apache.ibatis.executor.CachingExecutor.class
![](http://static.oschina.net/uploads/space/2016/0309/155902_PLdY_817621.png)
82行会从ms中取缓存配置,如果在mapper的xml中用<cache />开启了缓存,则此处cache!=null
84行判断是否要刷新缓存,这里是通过mapper的xml中<update id="delete" flushCache="flase">的flushCache来判断的,默认行为是select为false,update为true
85行是通过mapper的xml中的标签是<select><update>判断的,如果是select则isUseCache为true
接下来就是通过Key去取缓存,如果取到则直接返回该List,如果没有取到,则调用代理对象的查询方法,再把结果缓存起来
mybatis文档地址:http://www.mybatis.org/mybatis-3/zh/getting-started.html
mybatis-spring文档地址:http://www.mybatis.org/spring/zh/index.html
缓存
MyBatis 包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。MyBatis 3 中的缓存实现的很多改进都已经实现了,使得它更加强大而且易于配置。默认情况下是没有开启缓存的,除了局部的 session 缓存,可以增强变现而且处理循环 依赖也是必须的。要开启二级缓存,你需要在你的 SQL 映射文件中添加一行:
<cache/>
字面上看就是这样。这个简单语句的效果如下:
映射语句文件中的所有 select 语句将会被缓存。
映射语句文件中的所有 insert,update 和 delete 语句会刷新缓存。
缓存会使用 Least Recently Used(LRU,最近最少使用的)算法来收回。
根据时间表(比如 no Flush Interval,没有刷新间隔), 缓存不会以任何时间顺序 来刷新。
缓存会存储列表集合或对象(无论查询方法返回什么)的 1024 个引用。
缓存会被视为是 read/write(可读/可写)的缓存,意味着对象检索不是共享的,而 且可以安全地被调用者修改,而不干扰其他调用者或线程所做的潜在修改。
所有的这些属性都可以通过缓存元素的属性来修改。比如:
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
这个更高级的配置创建了一个 FIFO 缓存,并每隔 60 秒刷新,存数结果对象或列表的 512 个引用,而且返回的对象被认为是只读的,因此在不同线程中的调用者之间修改它们会 导致冲突。
可用的收回策略有:
LRU – 最近最少使用的:移除最长时间不被使用的对象。
FIFO – 先进先出:按对象进入缓存的顺序来移除它们。
SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象。
WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对
3ff0
象。
默认的是 LRU。
flushInterval(刷新间隔)可以被设置为任意的正整数,而且它们代表一个合理的毫秒 形式的时间段。默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新。
size(引用数目)可以被设置为任意正整数,要记住你缓存的对象数目和你运行环境的 可用内存资源数目。默认值是 1024。
readOnly(只读)属性可以被设置为 true 或 false。只读的缓存会给所有调用者返回缓 存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。可读写的缓存 会返回缓存对象的拷贝(通过序列化) 。这会慢一些,但是安全,因此默认是 false。
现在来通过源码看下他具体的实现逻辑:
org.apache.ibatis.session.Configuration.class
![](http://static.oschina.net/uploads/space/2016/0309/151622_NUnS_817621.png)
cacheEnabled是一个全局的Cache开关,是在mybatis-config.xml里配置的,配置方法为
<setting name="cacheEnabled" value="true"/>
其实这样的配置可以省略,因为mybatis默认是true。
org.apache.ibatis.builder.xml.XMLConfigBuilder.class
![](http://static.oschina.net/uploads/space/2016/0309/162516_O8Cd_817621.png)
CachingExecutor其实是一个代理对象,他代理了上一步创建的BatchExecutor或ReuseExecutor或SimpleExecutor。
当我们执行session的query方法时,他会转给我们的CachingExecutor的query
org.apache.ibatis.executor.CachingExecutor.class
![](http://static.oschina.net/uploads/space/2016/0309/155902_PLdY_817621.png)
82行会从ms中取缓存配置,如果在mapper的xml中用<cache />开启了缓存,则此处cache!=null
84行判断是否要刷新缓存,这里是通过mapper的xml中<update id="delete" flushCache="flase">的flushCache来判断的,默认行为是select为false,update为true
85行是通过mapper的xml中的标签是<select><update>判断的,如果是select则isUseCache为true
接下来就是通过Key去取缓存,如果取到则直接返回该List,如果没有取到,则调用代理对象的查询方法,再把结果缓存起来
mybatis文档地址:http://www.mybatis.org/mybatis-3/zh/getting-started.html
mybatis-spring文档地址:http://www.mybatis.org/spring/zh/index.html
相关文章推荐
- Mybatis 高级结果映射 ResultMap Association Collection
- Picasso fit() centerCrip() centerInside()
- Hadoop2.6集群动态添加和删除数据节点
- C# delegate多种变体
- convertToNodeSpace和convertToWorldSpace
- Spring学习笔记十三---动态代理
- 前端基础
- 用纯代码方式开发IOS应用程序
- CloudStack API 请求生成步骤
- JAVA编程经验
- 正规表达式的备忘录(吝啬匹配)
- STL标准库中基本数据结构的void*疑难
- Git添加报warning: LF will be replaced by CRLF问题解决方法
- saltstack 管理
- 怎么自定义ZBrush 4R7中按钮颜色
- 美石记韩式拌饭 多种口味任你挑
- 金汉亭自助涮烤 你的创富之需
- 御厨传奇涮烤一体 秒杀竞争对手
- 技巧:Vimdiff 使用
- 迈出走向程序员的第一步