缓存是分布式系统中的重要组件,主要解决高并发,大数据场景下,热点数据访问的性能问题。提供高性能的数据快速访问。
- 默认情况下,只启用了本地的会话缓存,它仅仅对一个会话中的数据进行缓存。
- 要启用全局的二级缓存,只需要在你的 SQL 映射文件中添加一行:
<cache/>
一级缓存
① 每当我们使用MyBatis开启一次和数据库的会话,MyBatis会创建出一个SqlSession对象表示一次数据库会话。
②一级缓存原理图
二级缓存
- 一级缓存作用域太低了,所以诞生了二级缓存。
- 基于namespace 级别的二级缓存,对应一个二级缓存。
- 当二级缓存开启后,同一个命名空间(namespace) 所有的操作语句,都影响着一个共同的 cache,也就是二级缓存被多个 SqlSession 共享,是一个全局的变量。当开启缓存后,数据的查询执行的流程就是 二级缓存 -> 一级缓存 -> 数据库。
二级缓存执行流程
二级缓存开启条件
①二级缓存默认是不开启的,需要手动开启二级缓存,实现二级缓存的时候,MyBatis要求返回的POJO必须是可序列化的。开启二级缓存的条件也是比较简单,通过直接在
MyBatis 配置文件中通过
<settings>
<setting name = "cacheEnabled" value = "true" />
</settings>
②还需要在 Mapper 对应的xml中添加 cache 标签,表示对哪个mapper 开启缓存
<!-- 表示DEPT表查询结果保存到二级缓存(共享缓存) -->
<cache/>
③设置select语句的参数 useCache=true
cache 标签有多个属性,一起来看一些这些属性分别代表什么意义
-
eviction: 缓存回收策略,有这几种回收策略
默认是 LRU 最近最少回收策略 -
flushinterval 缓存刷新间隔,缓存多长时间刷新一次,默认不清空,设置一个毫秒值
-
readOnly: 是否只读;true 只读,MyBatis 认为所有从缓存中获取数据的操作都是只读操作,不会修改数据。MyBatis 为了加快获取数据,直接就会将数据在缓存中的引用交给用户。不安全,速度快。读写(默认):MyBatis 觉得数据可能会被修改.
-
size : 缓存存放多少个元素
-
type: 指定自定义缓存的全类名(实现Cache 接口即可)
-
blocking: 若缓存中找不到对应的key,是否会一直blocking,直到有对应的数据进入缓存。
问题:我们需要将实体类序列化
总结:
- 只要在同一个Mapper下,二级缓存都可以使用
- 所有数据一开始都会在一级缓存中
- 只有当会话关闭了或者提交了,数据才会到二级缓存中
缓存执行原理
自定义缓存Ehcache
导包–>在类路径下配置xml文件—>type=org.xxx.xxx