Mybatis的二级缓存配置

一个项目中肯定会存在很多共用的查询数据,对于这一部分的数据,没必要

每一个用户访问时都去查询数据库,因此配置二级缓存将是非常必要的。

Mybatis的二级缓存配置相当容易,要开启二级缓存,只需要在你的Mapper

映射文件中添加一行:

它将采用默认的行为进行缓存:

映射文件中所有的select语句将被缓存

映射文件中所有的insert、update和delete语句将刷新缓存

缓存将使用LRU(Least Recently Used)最近最少使用策略算法来回收

刷新间隔(no Flush Interval,没有刷新间隔),缓存不会以任何时间顺序来刷新

缓存会存储列表集合和对象(无论查询方法返回什么)的1024个引用

缓存会被视为read/write(可读/可写)的缓存,意味着对象检索不是共享的,而且可以安全的被调用者修改,而不干扰其他调用者或者线程所做的潜在修改

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

eviction="FIFO"

flushInterval="10800000" size="512"

readOnly="true"

这个更高级的配置创建了一个FIFO缓存,并每隔3个小时刷新缓存,储存结

果对象或列表的512个引用,而且返回的对象被认为是只读的,因此在不同线程中的调用者之间修改他们会导致冲突。

可用的收回策略有:

【默认】LRU——最近最少使用的:移除最长时间不被使用的对象

FIFO——先进先出的:按对象进入缓存的顺序来移除他们

SOFT——软引用:移除基于垃圾回收器状态和软引用规则的对象

WEAK——弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。

flushInterval(刷新间隔)可以被设置为任意的正整数(60*60*1000这种形式是不允许的),而且它们代表一个合理的毫秒形式的时间段。默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新。

size(引用数目)可以被设置为任意正整数,要记住你缓存的对象数目和你运行环境的可用内存资源数目。默认值是1024.

readOnly(只读)属性可以被设置为true或false。只读的缓存会给所有调用者返回缓存对象的相同实例,因此这些对象不能被修改,这提供了很重要的性能优势。可读写的缓存会返回缓存对象的拷贝(通过发序列化)。这会慢一些,但是安全,因此默认是false。

配置完表示该mapper映射文件中,所有的select语句都将被缓存,所有的insert、update和delete语句都将刷新缓存。但是实际中,我们并是希望这样,有些select不想被缓存时,可以添加select的属性useCache=“false”;有些insert、update和delete不想让他刷新缓存时,添加属性flushCache=”false ”。

下面我分享一些我的收藏

高可用集群架构技术进阶篇手把手教你玩转Nginx与Docker

链接: https://pan.baidu.com/s/1A7Z75fN2UR-cteT8fgY5kQ 密码: yp8e

走向架构师,你必须了解的Java虚拟机高级特性

链接: https://pan.baidu.com/s/1hAPo19keNFHb9ycBctkU2A 密码: iayw

高并发处理技术老司机带你玩RabbitMq实现性能倍增

链接: https://pan.baidu.com/s/1nZNYXtqkmEAHPm1JKT2iBg 密码: y3sa

2018.07.09-T5架构师带你解读Spring源码~手写SpringMVC实战

链接: https://pan.baidu.com/s/1-NRFpVQd0TLyzT1SjskXdg 密码: 6amk

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180807A1TKY800?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券