MyBatis关于二级缓存问题
MyBatis提供一级缓存和二级缓存,其中一级缓存是sqlSession级别的缓存,不同的sqlSession之间的缓存互不影响。二级缓存是Mapper级别的缓存,多个sqlSession操作同一个Mapper,其二级缓存是可以共享的。
MyBatis有多种二级缓存方案可供选择。其中对Memcached的支持较为成熟,现以Memcached为例介绍与spring项目的集成。
使用配置
配置pom.xml,添加依赖。
<dependencies> ... <dependency> <groupId>org.mybatis.caches</groupId> <artifactId>mybatis-memcached</artifactId> <version>1.0.0</version> </dependency> ... </dependencies>
全局开关
<settings> <setting name="cacheEnabled" value="true"/> </settings>
配置需要缓存的mapper.xml
二级缓存是Mapper级别的,可以针对具体的mapper.xml开启二级缓存。
<mapper namespace="org.acme.FooMapper"> <cache type="org.mybatis.caches.memcached.MemcachedCache" /> </mapper>
开启后,则mapper中所有的select语句默认都将被缓存,此命名空间下所有insert、update、delete语句将会导致空间下的缓存被清空。
可以针对具体某条语句禁用缓存。
<select id="retObj" resultMap="results" useCache="false" > select id, name, sex from employee </select>
也可针对某条语句触发刷新动作(默认对应所有插入、更新、删除语句)。
<select id="retObj" resultMap="results" flushCache="true" > select id, name, sex from employee </select>
配置参数在memcached.properties中设置,如果缺失则使用缺省设置。
以下是配置参数:
如果需要记录cache操作日志,可由如下配置实现
<mapper namespace="org.acme.FooMapper"> <cache type="org.mybatis.caches.memcached.LoggingMemcachedCache" /> ... </mapper>
注意事项
缓存在Memcached中的类需要实现Serializable接口,否则会报错java.io.NotSerializableException。
二级缓存应用场景
- 对查询频率高,变化频率低的数据建议使用二级缓存。
- 对于访问多的查询请求且用户对查询结果实时性要求不高,此时可采用mybatis二级缓存技术降低数据库访问量,提高访问速度,业务场景比如:耗时较高的统计分析sql、电话账单查询sql等。
实现方法如下:
通过设置刷新间隔时间,由mybatis每隔一段时间自动清空缓存,根据数据变化频率设置缓存刷新间隔flushInterval,比如设置为30分钟、60分钟、24小时等,根据需求而定。
mybatis局限性
mybatis二级缓存对细粒度的数据级别的缓存实现不好。
比如如下需求:对商品信息进行缓存,由于商品信息查询访问量大,但是要求用户每次都能查询最新的商品信息,此时如果使用mybatis的二级缓存就无法实现当一个商品变化时只刷新该商品的缓存信息而不刷新其它商品的信息,因为mybaits的二级缓存区域以mapper为单位划分,当一个商品信息变化会将所有商品信息的缓存数据全部清空。解决此类问题需要在业务层根据需求对数据有针对性缓存。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。