设为首页 收藏本站
查看: 1045|回复: 0

[经验分享] Mybatis Cache探究

[复制链接]

尚未签到

发表于 2016-11-24 10:27:39 | 显示全部楼层 |阅读模式
  这里先不讨论第三方的cache集成(有memcache/oscache集成,控制力度跟下面说的一样比较粗,也可以跟spring3的cache做集成, spring3的cache是基于方法的缓存,具体可以在github找一下Spring MyBatis Memcached Bootstrap)。
  先使用最简单的配置cache,比较粗放:
  一,官方手册
  http://mybatis.github.io/mybatis-3/zh/sqlmap-xml.html#cache

<cache/>


字面上看就是这样。这个简单语句的效果如下:


  • 映射语句文件中的所有 select 语句将会被缓存。
  • 映射语句文件中的所有 insert,update 和 delete 语句会刷新缓存。
  • 缓存会使用 Least Recently Used(LRU,最近最少使用的)算法来收回。
  • 根据时间表(比如 no Flush Interval,没有刷新间隔), 缓存不会以任何时间顺序 来刷新。
  • 缓存会存储列表集合或对象(无论查询方法返回什么)的 1024 个引用。
  • 缓存会被视为是 read/write(可读/可写)的缓存,意味着对象检索不是共享的,而 且可以安全地被调用者修改,而不干扰其他调用者或线程所做的潜在修改。

所有的这些属性都可以通过缓存元素的属性来修改。比如:
 

<cache
eviction="FIFO"
flushInterval="60000"
size="512"
readOnly="true"/>
最重要的是readonly=ture, 说明cache对象只读,update的时候,cache不会更新!那么换个角度来说,
其实代表了发生任何insert,update,delete操作的时候,会全量清理cache数据,确保一致性。
 
如果readonly=false的时候,就比较好玩了,更新数据会写入新的cache,并且DO对象要实现序列化
[08/22 11:58:27][main] DEBUG org.apache.ibatis.cache.decorators.LoggingCache55: Cache Hit Ratio [com.xx.dao.UserMapper]: 0.25
 
[08/22 11:58:27][main] DEBUG org.springframework.jdbc.datasource.DataSourceUtils110: Fetching JDBC Connection from DataSource
 
二。测试代码
 
  流程是:
1.select id= 10035L,10036L的,数据
2.立即再查询10035L,cache命中
3.更新10035L数据
4.再查询10036L,cache未能命中
 
也就是说cache是全量清理的
 

/**
* 测试cache的读取和更新
* @author weisong
*
*/
public class MybatisCacheTest {
public static void main(String[] args) {
ApplicationContext ac = new ClassPathXmlApplicationContext("spring-core.xml","spring-task.xml","spring-jms.xml");
UserMapper u = (UserMapper)ac.getBean("userMapper");
User u0 = u.selectByPrimaryKey(10035L);  //sql
System.out.println("u0-name="+u0.getNickname());
User u00 = u.selectByPrimaryKey(10035L); //cache here! DEBUG org.apache.ibatis.cache.decorators.LoggingCache55: Cache Hit Ratio [com.xx.dao.UserMapper]: 0.0
System.out.println("u00(cache)-name="+u00.getNickname());
User u1 = u.selectByPrimaryKey(10036L);
u0.setNickname("wei");
u.updateByPrimaryKey(u0); //update here
User u01 = u.selectByPrimaryKey(10035L);
System.out.println("u01-name="+u01.getNickname()); //should no cache, next will cache
User u11 = u.selectByPrimaryKey(10036L);
System.out.println("u11-name="+u11.getNickname()); //!!!sql , no cache here

}
}
 
 
展开来继续说:
1.默然cache非常适合读多写少的小数据量级表;大数据量级很有可能cache重建的时候直接雪崩

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-304881-1-1.html 上篇帖子: MyBatis 1章 入门(使用MyBatis完成CRUD) 下篇帖子: mybatis小练习
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表