【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 ehcache是一个分布式缓存框架。 1.分布缓存 我们系统为了提高系统并发,性能、一般对系统进行分布式部署(集群部署方式) 如图 ...

【MyBatis框架】查询缓存-二级缓存-整合ehcache

mybatis整合ehcache ehcache是一个分布式缓存框架。 1.分布缓存 我们系统为了提高系统并发,性能、一般对系统进行分布式部署(集群部署方式) 如图 不使...

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

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

mybatis和hibernate一样都是优秀的orm框架,但是两者的定位不同,所以有所差异,这里我们就从缓存的角度来介绍一下mybatis: 大家都知道使用mybatis就要先获取sqlsessio...

MyBatis Review——整合ehcache

ehcache是一个分布式缓存框架,是hibernate中二级缓存的默认实现。    一,整合的思路      mybatis提供了一个cache接口,如果要实现自己的缓存逻辑,实现cache接口开发...

Mybatis - 查询缓存(一级缓存,二级缓存,与ehcache整合)

1.  为什么使用缓存?            用户减轻数据压力,提供数据库性能,提供了一级缓存和二级缓存;          一级缓存在操作数据库时需要构造SqlSes...

mybatis教程--查询缓存(一级缓存二级缓存和整合ehcache)

查询缓存 1 缓存的意义 将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题。    ...

SpringMVC mybatis or hibernate ehcache二级缓存maven非和maven版本

获取【下载地址】   QQ: 313596790   【免费支持更新】 A 代码生成器(开发利器);全部是源码      增删改查的处理类,service层,mybatis的xml,SQL( my...

MyBatis中如何合理的使用EhCache缓存框架

缓存简介 缓存使用场景 在mapperxml中启用Ehcache 当为Select语句时 当为insertupdatedelete语句时 配置场景 使用举例关于详细配置方面已经在另一篇文章中说过:My...

SpringMVC mybatis or hibernate ehcache二级缓存maven非和maven版本

A 调用摄像头拍照,自定义裁剪编辑头像 【新录针对本系统的视频教程,手把手教开发一个模块,快速掌握本系统】 B 集成代码生成器 [正反双向](单表、主表、明细表、树形表,开发利器)+快速构建表...

SpringMVC mybatis or hibernate ehcache二级缓存maven非和maven版本

获取【下载地址】   QQ: 313596790   【免费支持更新】 支持三大数据库 mysql  oracle  sqlsever   更专业、更强悍、适合不同用户群体 【新录针对本系统的...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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