spring和mybatis中的连接池和缓存

文章目录

    • 十、连接池
      • 10.1连接池
      • 10.2、mybatis连接池的分类
    • 十一、mybatis的缓存
      • 一级缓存和二级缓存
      • 使用一级缓存失效的四种情况:
        • 11.1、不同的SqlSession对应不同的一级缓存。
        • 11.2、MyBatis的二级缓存
      • 二级缓存开启的条件:
        • 11、3二级缓存的相关配置
        • 11.4、mybatis缓存查询的顺序
        • 11.5整合第三方的缓存EhCache

十、连接池

10.1连接池

  1. 连接池是什么:存储连接的容器

  2. 解决了什么问题

    • 如果没有连接池,每次执行sql语句都需要创建connection的连接,会浪费时间,影响程序的性能。
  3. 提前创建一些连接,存储到连接池中,使用的时候从连接池获取连接即可

  4. 常用的连接池

    1. c3p0

    2. dbcp

    3. druid(阿里)

  5. 连接池有归还的操作,已经对close方法进行了增强,原来是关闭连接,现在是归还

10.2、mybatis连接池的分类

  1. 在解析mybatis-config.xml配置文件的时候,创建dataSource对象,存入到Environment对象中。

  2. 当执行SQL语句的时候,准备从dataSource对象中获取链接。

十一、mybatis的缓存

一级缓存和二级缓存

一级缓存是SqlSession级别的,通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就会从一级缓存中直接获取,不会从数据库重新查询。一级缓存默认是开启

使用一级缓存失效的四种情况:

11.1、不同的SqlSession对应不同的一级缓存。
@Test
public void testGetEmpById(){SqlSession sqlSession1 = SqlSessionUtil.getSqlSession();System.out.println(sqlSession1);SqlSession sqlSession2 = SqlSessionUtil.getSqlSession();System.out.println(sqlSession2);EmpMapper empMapper1 = sqlSession1.getMapper(EmpMapper.class);Emp emp1 = empMapper1.getEmpById(1);System.out.println(emp1);System.out.println("-----------------------------------");EmpMapper empMapper2 = sqlSession2.getMapper(EmpMapper.class);Emp emp2 = empMapper2.getEmpById(1);System.out.println(emp2);
}

2、同一个SqlSession但是查询条件不同。

3、同一个SqlSession两次查询之间,执行了任何一次增删改操作

Emp emp1 = empMapper.getEmpById(1);
System.out.println(emp1);empMapper.insertEmp(new Emp(null,"小张",23,"男"));Emp emp2 = empMapper.getEmpById(1);
System.out.println(emp2);

4、同一个SqlSession两次查询之间,手动清空了缓存

//手动清空一级缓存
sqlSession.clearCache();
11.2、MyBatis的二级缓存

二级缓存是SqlSessionFactory级别的,通过同一个SqlSessionFactory创建的SqlSession查询的结果都会被缓存;下次查询相同的数据,就会从二级缓存中直接获取,不会从数据库重新查询。二级缓存默认是不开启的

二级缓存开启的条件:

1、在核心配置文件中,设置全局配置属性cacheEnabled=”true” ,默认为true。所以不需要设置

2、在映射文件中设置标签

3、二级缓存必须在SqlSession关闭之后生效

4、查询的数据所转换的实体类类型必须实现序列化的接口

public class Emp implements Serializable 
@Test
public void testCache() throws IOException {InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream);/*sqlSession1和sqlSession2都是sqlSessionFactory创建的*/SqlSession sqlSession1 = sqlSessionFactory.openSession(true);EmpMapper empMapper1 = sqlSession1.getMapper(EmpMapper.class);Emp emp1 = empMapper1.getEmpById(1);System.out.println(emp1);sqlSession1.close();System.out.println("-----------------------");SqlSession sqlSession2 = sqlSessionFactory.openSession(true);EmpMapper empMapper2 = sqlSession2.getMapper(EmpMapper.class);Emp emp2 = empMapper2.getEmpById(1);System.out.println(emp2);sqlSession2.close();
}

Cache Hit Ratio:二级缓存命中率,不为0,说明程序直接从二级缓存中获取了数据

使二级缓存失效的情况:

两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效

11、3二级缓存的相关配置

在mapper配置文件中添加的cache标签可以设置一些属性:

①eviction属性:缓存回收策略,默认的是 LRU。

LRU(Least Recently Used) – 最近最少使用的:移除最长时间不被使用的对象。

FIFO(First in First out) – 先进先出:按对象进入缓存的顺序来移除它们。

SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象。

WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象。

②flushInterval属性:刷新间隔,单位毫秒

默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句时刷新

③size属性:引用数目,正整数代表缓存最多可以存储多少个对象,太大容易导致内存溢出

④readOnly属性:只读, true/false

true:只读缓存;会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。

false:读写缓存;会返回缓存对象的拷贝(通过序列化)。这会慢一些,但是安全,因此默认是false。

11.4、mybatis缓存查询的顺序

先查询二级缓存,因为二级缓存中可能会有其他程序已经查出来的数据,可以拿来直接使用。

如果二级缓存没有命中,再查询一级缓存

如果一级缓存也没有命中,则查询数据库

SqlSession关闭之后,一级缓存中的数据会写入二级缓存

11.5整合第三方的缓存EhCache

11.5.1添加依赖

<!-- Mybatis EHCache整合包 -->
<dependency><groupId>org.mybatis.caches</groupId><artifactId>mybatis-ehcache</artifactId><version>1.2.1</version>
</dependency>
<!-- slf4j日志门面的一个具体实现 -->
<dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.3</version>
</dependency>	

11.5.2各jar的功能

jar包名称作用
mybatis-ehcacheMybatis和EHCache的整合包
ehcacheEHCache核心包
slf4j-apiSLF4J日志门面包
logback-classic支持SLF4J门面接口的一个具体实现

11.5.3创建EHCache配置文件ehcache.xml

<?xml version="1.0" encoding="utf-8" ?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:noNamespaceSchemaLocation="../config/ehcache.xsd"><!-- 磁盘保存路径 --><diskStore path="D:\qingcheng\ehcache"/><defaultCachemaxElementsInMemory="1000"maxElementsOnDisk="10000000"eternal="false"overflowToDisk="true"timeToIdleSeconds="120"timeToLiveSeconds="120"diskExpiryThreadIntervalSeconds="120"memoryStoreEvictionPolicy="LRU"></defaultCache>
</ehcache>

11.5.4设置二级缓存的类型

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

11.5.5加入logback日志

存在SLF4J时,作为简易日志的log4j将失效,此时需要借助SLF4J的具体实现logback来打印日志,创建logback的配置文件logback.xml

11.5.6EHCache配置文件说明

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

|
| diskExpiryThreadIntervalSeconds | 否 | 磁盘缓存的清理线程运行间隔,默认是120秒。每个120s,相应的线程会进行一次EhCache中数据的清理工作 |
| memoryStoreEvictionPolicy | 否 | 当内存缓存达到最大,有新的element加入的时候,移除缓存中element的策略。默认是LRU(最近最少使用),可选的有LFU(最不常使用)和FIFO(先进先出) |

11.5.7 测试还用之前的测试方法即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/25929.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机视觉与深度学习实战,Python为工具,基于计算机视觉的自动驾驶应用

一、引言 随着人工智能技术的飞速发展,计算机视觉与深度学习已成为当今科技领域的热点。其中,自动驾驶技术作为二者的完美结合,已经引起了广泛关注。自动驾驶技术依赖于计算机视觉实现对周围环境的感知与理解,通过深度学习对大量数据进行处理和分析,从而实现无人驾驶的目标…

pytest中失败用例重跑

pip install pytest-rerunfailures 下载rerunfailures插件包 配置文件中加入命令 --reruns 次数 也可在命令行中pytest --rerun-failures2 可以在allure报告中看到重试效果

【Echarts系列】水平柱状图

【Echarts系列】水平柱状图 序示例数据格式代码 序 为了节省后续开发学习成本&#xff0c;这个系列将记录我工作所用到的一些echarts图表。 示例 水平柱状图如图所示&#xff1a; 数据格式 data [{name: 于洪区,value: 2736},{name: 新民市,value: 2844},{name: 皇姑区,…

使用v-for实现点击当前li,li背景颜色变为红色,其余颜色不变

在 Vue 3 中&#xff0c;可以使用 <script setup> 语法糖来简化组件的编写。 下面是一个使用 Vue 3 和 <script setup> 实现的示例&#xff1a; <template> <ul> <li v-for"(item, index) in items" :key"index" :cl…

C++:SLT容器-->queue

C:SLT容器-->queue 1. queue容器2. queue 常用接口 1. queue容器 先进先出队列允许从一端插入元素&#xff0c;从另一端删除元素队列中只有队头和队尾可以被外界使用&#xff0c;因此队列不允许有遍历行为队列中插入数据称为入队(push)&#xff0c;删除数据称为出队(pop) …

JS 实现动态规划

function getPaths(m, n) {// m * n 二维数组&#xff0c;模拟网格const map new Array(m)for (let i 0; i < m; i) {map[i] new Array(n)}// 如果只走第一行&#xff0c;就只有一条路径。所以第一行所有 item 都填充 1map[0].fill(1)// 如果只走第一列&#xff0c;也只有…

ADAS功能规范总览

前提 本文对ADAS算法相关功能规范进行详细分解&#xff0c;本专栏是对自动驾驶相关从业者进行入门指导&#xff0c;会对功能算法各个部分进行详细梳理&#xff0c;如有不同见解评论或私信交流。相关ADAS的简化版本规范请关注我的ADAS辅助驾驶算法专栏。 功能规范 会按照以下…

快速删除 node_modules

在Windows系统上删除 node_modules 文件夹通常会比较慢&#xff0c;主要原因有以下几个&#xff1a; 1.文件数量多且嵌套深&#xff1a;node_modules 文件夹通常包含大量的子文件夹和文件&#xff0c;其中一些可能嵌套得非常深。Windows在删除文件和文件夹时&#xff0c;需要遍…

【vue3|第8期】深入理解Vue 3 computed计算属性

日期&#xff1a;2024年6月10日 作者&#xff1a;Commas 签名&#xff1a;(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释&#xff1a;如果您觉得有所帮助&#xff0c;帮忙点个赞&#xff0c;也可以关注我&#xff0c;我们一起成长&#xff1b;如果有不对的地方&#xf…

合约ABI探秘

EOA使用ABI调用 合约之间使用接口调用 自己写ABI&#xff0c;自己写接口 ABI探秘 EOA使用的ABI数据与合约间调用时调用者持有的接口时等价的&#xff0c;都是对合约函数签名的完整描述调用者使用ABI数据生成message中的calldata message上下文的变化 合约之间的调用也模拟…

8.11 矢量图层线要素单一符号使用六(光栅线)

文章目录 前言光栅线&#xff08;Raster Line&#xff09;QGis设置线符号为光栅线&#xff08;Raster Line&#xff09;二次开发代码实现光栅线&#xff08;Raster Line&#xff09; 总结 前言 本章介绍矢量图层线要素单一符号中光栅线&#xff08;Raster Line&#xff09;的使…

node设置镜像源详细教程

在Node.js环境中&#xff0c;你可以通过设置npm或yarn的镜像源来加速依赖包的下载。以下是如何设置npm和yarn的镜像源的详细步骤&#xff1a; 使用npm设置镜像源 临时设置镜像源&#xff1a; 你可以在安装包时临时指定镜像源&#xff0c;例如&#xff1a; npm install package…

FastWeb网站开发之拦截器(interceptor)使用教程

拦截器用于拦截和处理HTTP请求和响应。在请求开始处理之前进行拦截过滤与处理。 API文档 拦截器一般用于初始化lua脚本中创建拦截规则。 它主要用于浏览器的请求中某些目录或文件不允许访问、某些目录需要验证权限&#xff0c;在拦截器中进行判断并选择是否继续向下执行。 …

在Spigot插件中配置指令

在Spigot插件中配置指令 在Spigot插件开发中&#xff0c;配置指令&#xff08;命令&#xff09;是非常重要的一部分。通过自定义指令&#xff0c;玩家可以与插件进行交互&#xff0c;触发特定的功能和行为。本文将详细介绍如何在Spigot插件中配置指令&#xff0c;并通过一个简…

【C语言】32个关键字

C语言32个关键字 文章目录 C语言32个关键字1.数据类型关键字基本数据类型&#xff08;5个&#xff09;类型修饰关键字&#xff08;4个&#xff09;复杂类型关键字&#xff08;5个&#xff09;存储级别关键字&#xff08;6个&#xff09; 2.流程控制关键字跳转结构&#xff08;4…

如何通过加密U盘 实现数据传输闭环管控?

加密U盘是用来保护存储在其中数据的安全的。通过加密技术&#xff0c;用户可以将其敏感文件和信息存储在U盘中&#xff0c;并设置密码或使用其他加密方法来防止未经授权的访问。这种安全措施可以防止数据泄露或盗窃&#xff0c;特别是在丢失或被盗的情况下&#xff0c;确保数据…

一些简单却精妙的算法

文章目录 1.树状数组2.红黑树3.星星打分4.欧几里得算法5.快速幂6.并查集 在编程的世界里&#xff0c;简洁的代码往往隐藏着深邃的智慧。一起来看看那些看似简单&#xff0c;实则精妙绝伦的代码片段&#xff0c;体会编程语言的优雅与力量。 1.树状数组 int lowbit(int x) { …

机床联网第一课

一、不是废话的废话 照例第一篇文章先介绍下整个专栏系列的内容和背景&#xff0c;这篇文章不涉及任何代码和技术知识&#xff0c;大家都能看得懂。 1、写作初衷 自入行接触设备数据采集、设备联网工作近十年&#xff0c;期间记不清有多少次有人请我帮忙去处理公司外部的项目&…

软件下载网站源码附手机版和图文教程

PHP游戏应用市场APP软件下载平台网站源码手机版 可自行打包APP&#xff0c;带下载统计&#xff0c;带多套模板&#xff0c;带图文教程&#xff0c;可以做软件库&#xff0c;也可以做推广app下载等等&#xff0c;需要的朋友可以下载 源码下载 软件下载网站源码附手机版和图文…

新加坡高防服务器的特点

新加坡高防服务器是指位于新加坡的高性能、高安全性的服务器&#xff0c;通常用于托管网站、应用程序和其他在线服务。这类服务器通常具有以下特点&#xff0c;rak部落为您整理发布。 1. 高速网络连接&#xff1a;新加坡是亚洲地区的主要互联网枢纽&#xff0c;拥有高质量的网络…