🌈有幸相识 ,我是小相。有一个大厂梦,努力奔赴!加油陌生人!🌈
☁️该文章是跟随B站狂神学习Mybatis时的笔记与心得,若与您有用,感谢点赞。文章不免有不足之处,请指出,我会及时改正!
1. 简介
将用户经常查询的数据结果保存到内存,用户在查询的时候就不用到数据库文件中查询(磁盘),从而减少与数据库的交付次数提高了响应速度,解决了并发系统的西能问题。mybatis提供了两种类型的缓存,一级缓存和二级缓存。mybatis默认开启一级缓存。
- 用途:高性能**、**高并发
- 映射语句文件中的所有 select 语句的结果将会被缓存。
- 映射语句文件中的所有 insert、update 和 delete 语句会刷新缓存。
- 缓存会使用最近最少使用算法(LRU, Least Recently Used)算法来清除不需要的缓存。
- 缓存不会定时进行刷新(也就是说,没有刷新间隔)。
2. 一级缓存
mybatis中默认开启一级缓存,这是sqlSession级别的缓存,也称为本地缓存,他仅仅对一个会话中的数据进行缓存即从获取selSession到sqlSession关闭。
3. 二级缓存
mybatis中默认没有开启二级缓存,二级缓存是namespace级别的。开启二级缓存后,当管理sqlSession后,其数据内容将会从一级缓存变为二级缓存。
若要启用二级缓存,需要以下步骤:
- 在核心配置文件中开启缓存
<setting name="cacheEnabled" value="true"/>
- 在SQL映射文件mapper.xml中添加 <cache/>标签即可。
<cache/>
3.1 cache属性
<cache
eviction="FIFO"
flushInterval="60000"
size="512"
readOnly="true"/>
这个更高级的配置创建了一个 FIFO 缓存,每隔 60 秒刷新,最多可以存储结果对象或列表的 512 个引用,而且返回的对象被认为是只读的,因此对它们进行修改可能会在不同线程中的调用者产生冲突。
可用的清除策略有:
LRU
– 最近最少使用:移除最长时间不被使用的对象。FIFO
– 先进先出:按对象进入缓存的顺序来移除它们。SOFT
– 软引用:基于垃圾回收器状态和软引用规则移除对象。WEAK
– 弱引用:更积极地基于垃圾收集器状态和弱引用规则移除对象。
默认的清除策略是 LRU。
flushInterval(刷新间隔)属性可以被设置为任意的正整数,设置的值应该是一个以毫秒为单位的合理时间量。 默认情况是不设置,也就是没有刷新间隔,缓存仅仅会在调用语句时刷新。
size(引用数目)属性可以被设置为任意正整数,要注意欲缓存对象的大小和运行环境中可用的内存资源。默认值是 1024。
readOnly(只读)属性可以被设置为 true 或 false。只读的缓存会给所有调用者返回缓存对象的相同实例。 因此这些对象不能被修改。这就提供了可观的性能提升。而可读写的缓存会(通过序列化)返回缓存对象的拷贝。 速度上会慢一些,但是更安全,因此默认值是 false。
4. 缓存原理
- 用户自二级缓存开始查询,若二级缓存中没有对应信息则去一级缓存中查找,最后才是连接数据库进行查询。