【MyBatis】——mybatis缓存以及整合ehcache

原创 2016年06月14日 14:38:56

            首先向介绍一下mybatis的缓存以及为什么使用缓存。


MyBatis缓存介绍

            hibernate等其他持久层框架一样,mybatis同样提供了一级缓存和二级缓存的支持,用于减轻数据压力,提高数据库性能。


            一级缓存时SqlSession级别的缓存。在操作数据库时需要构造sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。

 

            二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。


为什么要用缓存?

            如果缓存中有数据就不用从数据库中获取,大大提高系统性能。

 

一、整合原因

        首先ehcache是一个分布式缓存框架。当缓存的数据在各个服务单独存储,这样就不方便系统开发,系统为了提高系统并发,性能,所以要使用分布式缓存对缓存数据进行集中管理。而mybatis无法实现分布式缓存,需要和其他分布式缓存框架进行整合。


二、整合原理

mybatis提供二级缓存Cache接口,如下:

            

它的默认实现类:

            

            通过实现Cahce接口可以实现mybatis缓存数据通过其它缓存数据库整合,mybatis的特长是sql操作,缓存数据的管理不是myabatis的特长,为了提高缓存的性能将mybatis和第三发的缓存数据库整合。

 

三、整合方法

1、引入缓存需要的jar

            

2、引入缓存配置文件

            classpath下配置ehcache.xml

<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">
	<diskStore path="F:\develop\ehcache" />
	<defaultCache 
		maxElementsInMemory="1000" 
		maxElementsOnDisk="10000000"
		eternal="false" 
		overflowToDisk="false" 
		timeToIdleSeconds="120"
		timeToLiveSeconds="120" 
		diskExpiryThreadIntervalSeconds="120"
		memoryStoreEvictionPolicy="LRU">
	</defaultCache>
</ehcache>

3、开启ehcache缓存

            配置mapper中的cache中的typeehcachecache接口的实现类型

            修改mapper.xml文件,在cache中指定EhcacheCache

<cache type="org.mybatis.caches.ehcache.EhcacheCache"/>

四、应用场景

            对于访问多的查询请求且用户对查询结果实时性要求不高,此时可采用mybatis二级缓存技术降低数据库访问量,提高访问速度,业务场景比如:耗时较高的统计分析sql、电话账单查询sql等。

            实现方法如下:通过设置刷新间隔时间,由mybatis每隔一段时间自动清空缓存,根据数据变化频率设置缓存刷新间隔flushInterval,比如设置为30分钟、60分钟、24小时等,根据需求而定。

 

五、局限性

            mybatis二级缓存对细粒度的数据级别的缓存实现不好,比如如下需求:对商品信息进行缓存,由于商品信息查询访问量大,但是要求用户每次都能查询最新的商品信息,此时如果使用mybatis的二级缓存就无法实现当一个商品变化时只刷新该商品的缓存信息而不刷新其它商品的信息,因为mybaits的二级缓存区域以mapper为单位划分,当一个商品信息变化会将所有商品信息的缓存数据全部清空。解决此类问题需要在业务层根据需求对数据有针对性缓存。



版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Mybatis与Ehcache整合

Mybatis与Ehcache整合可以提高性能,降低数据库压力。查询百度发现整合其实非常简单的...

spring+mybatis+ehcache配置缓存

1:spring加载ehcache配置文件

spring mvc+mybatis ehcache缓存配置

1.下载mybatis相关包与ehcache相关包 下载地址为:https://github.com/mybatis/ehcache-cache/releases 配置文件 ehcache.xm...

springMVC+mybatis+ehcache详细配置

一、 Mybatis+Ehcache配置为了提高MyBatis的性能,有时候我们需要加入缓存支持,目前用的比较多的缓存莫过于ehcache缓存了,ehcache性能强大,而且位各种应用都提供了解决方案...

ehcache +mybatis+spring 自定义缓存策略

从3.1开始,Spring引入了对Cache的支持。其使用方法和原理都类似于Spring对事务管理的支持。Spring Cache是作用在方法上的,其核心思想是这样的:当我们在调用一个缓存方法时会把该...

mybatis的缓存配置--ehcache.xml(缓存配置文件)

web项目 ehcache 单独配置

private static CacheManager singletonManager = CacheManager.create(CacheUtils.class.getResource("/")...

android获取web服务器端session并验证登陆 二

接上文: 2.)服务器端(php)php服务器端主要有三个文件,conn.php,login.php和getinfo.php。 1. conn.php是连接数据库的配置文件。 2. login....

mybatis整合ehcache分布式二级缓存框架的使用

mybaits的二级缓存是mapper范围级别,除了在SqlMapConfig.xml设置二级缓存的总开关,还要在具体的mapper.xml中开启二级缓存。 1.开启mybatis的二级缓存   ...

mybatis一二级缓存详解,整合ehcache缓存,

mybatis和hibernate一样都是优秀的orm框架,但是两者的定位不同,所以有所差异,这里我们就从缓存的角度来介绍一下mybatis: 大家都知道使用mybatis就要先获取sqlsessio...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【MyBatis】——mybatis缓存以及整合ehcache
举报原因:
原因补充:

(最多只允许输入30个字)