MybatisPlus二级缓存
-
Mybatis缓存体系探究,提供基于MybatisPlus技术可用于生产环境下的二级缓存解决方案。
Mybatis的二级缓存Mapper级别的,sqlSession共享,它是把namespace做作为缓存key实现的,各个namespace是独立的,互相不影响。而具体的sql查询语句是根据命名namespace、查询语句及查询参数等拼接的一个缓存key,value值是第一次从数据库查询出来的结果,value需要实现Serilizable接口(流化、字节化),因为mybatis的缓存value值是字节数组。实现: SpringBoot默认是开启二级缓存的。如果想要单独那个Mapper实现cache,可以在xxxMapper.xml文件中添加即可。注意在xml文件中配了。
目标与收获:如果应用有分布式缓存需求,那么直接弃用二级缓存的方案,直接选配业务层缓存方案。
假如应用没有分布式场景,那么通过简单改造,引入二级缓存,能够极大提高响应效率。选用MybatisPlus来实现二级缓存最大的考量是其使用的单表操作,换而言之,正确的使用二级缓存的前提是不能使用传统意义上的多表连接操作,否则一定存在缓存数据不能实时更新的情况。缓存数据更新:所有的缓存数据必然涉及到数据更新,二级缓存同样需要主动更新数据。二级缓存是以命名空间为单位的,换而言之同一个命名空间内的数据更新会自动触发缓存更新。查询操作缓存数据,增加、修改、删除数据使缓存失效。
自成体系的缓存更新与管理在提高了应用响应速度的同时降低了缓存管理的复杂度,有利于提高开发效率。
缓存的区别:这里提到的二级缓存有必要与三级缓存(业务缓存)做区分,二级缓存指DAO层缓存,使用缓存的目的是降低网络IO对应用的影响;三级缓存指业务层缓存,主要是降低复杂计算对CPU性能的占用。
MybatisPlus内置封装两套访问数据库的API,一是以BaseMapper为基础的API,另一套是以AR为基础的API,二者在使用二级缓存不可通用。表现形式是BaseMapper内置接口缓存的数据,使用AR内置接口更新数据时无法清楚缓存,至少到此版本尚不支持。
考虑到BaseMapper接口体系比较丰富,因此选择保留BaseMapper体系接口而禁用AR接口,从机制上保证使用的是一套接口,从而调用增删查改能够实时刷新二级缓存。
需要指明的是Mapper层和Service层使用的是同一套接口,因此可放心使用。
西南地区IT社群(QQ)
- 云南
- 【昆明网页设计交流吧】243627302
- 【昆明nodejs交流吧】 243626749
- 【VUE】838405306
- 【云南程序员总群】343606807
- 【昆明UI设计】104031254
- 【云南软件外包】15547313
- 贵州
- 【PHP/java源码/站长交流群】55692114
- 四川
- 【成都Java/JavaWeb交流】86669225
- 【vaScript+PHP+MySql】116270060
- 【UI设计/设计交流学习群】135794928
- 重庆
- 【诺基亚 JAVA游戏博物馆】 559479780
- 【PHP,Java,Python,C++接单】 442103442
- 西藏