ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Mybatis --- 缓存机制

2019-09-19 14:00:48  阅读:221  来源: 互联网

标签:缓存 作用域 二级缓存 默认 element SqlSession Mybatis 机制


Mybatis — 缓存机制

* 上一篇说到在Mybatis中的动态SQLMybatis — 动态SQL
* 这一篇主要来讲解Mybatis中的缓存机制

了解:

  • MyBatis 包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。缓存可以极大的提升查询效率。
  • MyBatis系统中默认定义了两级缓存。
  • 默认情况下,只有一级缓存(SqlSession级别的缓存,也称为本地缓存)开启。
  • 二级缓存需要手动开启和配置,他是基于namespace级别的缓存。
  • 为了提高扩展性。MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存。

一丶 一级缓存

• 一级缓存(local cache), 即本地缓存, 作用域默认为sqlSession。当 Session flush 或 close 后, 该Session 中的所有 Cache 将被清空。
• 本地缓存不能被关闭, 但可以调用 clearCache() 来清空本地缓存, 或者改变缓存的作用域. • 在mybatis3.1之后, 可以配置本地缓存的作用域. 在 mybatis.xml 中配置
• 演示:同一次会话期间只要查询过的数据都会保存在当前SqlSession的一个Map中
key : hashCode+查询的SqlId+编写的sql查询语句+参数
• 一级缓存失效情况 :
  • 不同的SqlSession对应不同的一级缓存
  • 同一个SqlSession但是查询条件不同
  • 同一个SqlSession两次查询期间执行了任何一次增删改操作
  • 同一个SqlSession两次查询期间手动清空了缓存

二丶 二级缓存

• 二级缓存(second level cache),全局作用域缓存
• 二级缓存默认不开启,需要手动配置
• MyBatis提供二级缓存的接口以及实现,缓存实现要求POJO实现Serializable接口
• 二级缓存在 SqlSession 关闭或提交之后才会生效
• 使用步骤

1、全局配置文件中开启二级缓存

<setting name="cacheEnabled" value="true"/>

2、需要使用二级缓存的映射文件处使用cache配置缓存

<cache eviction="FIFO" flushInterval="60000" readOnly="false" size="1024"></cache>

3、注意:POJO需要实现Serializable接口

public class Employee implements Serializable

三丶 缓存相关属性

<cache eviction="FIFO" flushInterval="60000" readOnly="false" size="1024"></cache>
  • eviction=“FIFO”: 缓存回收策略:
    • LRU – 最近最少使用的:移除最长时间不被使用的对象。
    • FIFO – 先进先出:按对象进入缓存的顺序来移除它们。
    • SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象。
    • WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。
    • 默认的是 LRU。
  • flushInterval: 刷新间隔,单位毫秒
    • 默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新
  • size: 引用数目,正整数
    • 代表缓存最多可以存储多少个对象,太大容易导致内存溢出
  • readOnly: 只读,true/false
    • true:只读缓存;会给所有调用者返回缓存对象的相同实例。因此这些对象
      不能被修改。这提供了很重要的性能优势。
    • false:读写缓存;会返回缓存对象的拷贝(通过序列化)。这会慢一些,
      但是安全,因此默认是 false。

四丶 缓存有关设置

  • 全局setting的cacheEnable:
    • 配置二级缓存的开关。一级缓存一直是打开的。
      在这里插入图片描述
  • 2、select标签的useCache属性:
    • 配置这个select是否使用二级缓存。一级缓存一直是使用的
      在这里插入图片描述
  • 3、sql标签的flushCache属性:
    • 增删改默认flushCache=true。sql执行以后,会同时清空一级和二级缓存。查询默认flushCache=false。
      在这里插入图片描述
  • 4、sqlSession.clearCache():
    • 只是用来清除一级缓存。
		//sqlSession相同,手动清除了一级缓存(缓存清空)
		//openSession.clearCache();
  • 5、当在某一个作用域 (一级缓存Session/二级缓存Namespaces) 进行了 C/U/D 操作后,默认该作用域下所 有 select 中的缓存将被clear。

五丶 第三方缓存整合(EhCache)

  • 步骤:

    • 导入ehcache包,以及整合包,日志包
      ehcache-core-2.6.8.jar、mybatis-ehcache-1.0.3.jar
      slf4j-api-1.6.1.jar、slf4j-log4j12-1.6.2.jar
      在这里插入图片描述
    • 编写ehcache.xml配置文件
	<?xml version="1.0" encoding="UTF-8"?>
	<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	 xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">
	 	<!-- 
		属性说明:
		l diskStore:指定数据在磁盘中的存储位置。
		l defaultCache:当借助CacheManager.add("demoCache")创建Cache时,EhCache便会采用<defalutCache/>指定的的管理策略

		以下属性是必须的:
		l maxElementsInMemory - 在内存中缓存的element的最大数目 
		l maxElementsOnDisk - 在磁盘上缓存的element的最大数目,若是0表示无穷大
		l eternal - 设定缓存的elements是否永远不过期。如果为true,则缓存的数据始终有效,如果为false那么还要根据timeToIdleSeconds,timeToLiveSeconds判断
		l overflowToDisk - 设定当内存缓存溢出的时候是否将过期的element缓存到磁盘上
		 
		以下属性是可选的:
		l timeToIdleSeconds - 当缓存在EhCache中的数据前后两次访问的时间超过timeToIdleSeconds的属性取值时,这些数据便会删除,默认值是0,也就是可闲置时间无穷大
		l timeToLiveSeconds - 缓存element的有效生命期,默认是0.,也就是element存活时间无穷大
		 diskSpoolBufferSizeMB 这个参数设置DiskStore(磁盘缓存)的缓存区大小.默认是30MB.每个Cache都应该有自己的一个缓冲区.
		l diskPersistent - 在VM重启的时候是否启用磁盘保存EhCache中的数据,默认是false。
		l diskExpiryThreadIntervalSeconds - 磁盘缓存的清理线程运行间隔,默认是120秒。每个120s,相应的线程会进行一次EhCache中数据的清理工作
		l memoryStoreEvictionPolicy - 当内存缓存达到最大,有新的element加入的时候, 移除缓存中element的策略。默认是LRU(最近最少使用),可选的有LFU(最不常使用)和FIFO(先进先出)
	 -->
	 <diskStore path="D:\44\ehcache" />
	 <defaultCache 
	   maxElementsInMemory="10000" 
	   maxElementsOnDisk="10000000"
	   eternal="false" 
	   overflowToDisk="true" 
	   timeToIdleSeconds="120"
	   timeToLiveSeconds="120" 
	   diskExpiryThreadIntervalSeconds="120"
	   memoryStoreEvictionPolicy="LRU">
	 </defaultCache>
	</ehcache>
  • 配置cache标签
    <cache type="org.mybatis.caches.ehcache.EhcacheCache"></cache>
    
  • 参照缓存:

    在DepartmentMapper.xml中:
    在这里插入图片描述

大致流程 :

在这里插入图片描述

END …

以上就是Mybatis中的缓存机制 ,欢迎参考交流 …

标签:缓存,作用域,二级缓存,默认,element,SqlSession,Mybatis,机制
来源: https://blog.csdn.net/weixin_43287239/article/details/100828916

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有