21. Hibernate 性能之数据库连接池

1. 前言

从本节课程开始,和大家一起聊聊 Hibernate 中的性能问题,面对开发者,Hibernate 表现出卓越的数据库操作能力。

使用框架最大的优势就是带来操作的快捷、便利。同时,因为框架的封装性,其性能往往比原生开发要慢。所以了解、掌握 Hibernate 的性能调优方案是提升性能的不二法则。

了解其性能优化方案,编写最好的性能优化策略,对每一个开发者而言,都是一个必选题。通过本节课程的学习,你将了解到:

  • 什么是数据库连接池;
  • HIbernate 中如何使用数据库连接池。

2. 数据库连接池

面对大量的数据库操作请求,数据库连接池能很好地帮助 Hibernate 避开网络开销所产生的性能消耗。

什么是数据库连接池?

一般讲池子是用来养鱼的,但数据库连接池不是养鱼的,而是养了好多的 Connection 对象。

当应用程序需要一个连接对象时,便向连接池租用一个。用完后,再返回给连接池,这样连接池中的连接对象便可以反复使用,达到重用连接对象的目的。

Connection 的功能本质是通过网络 API 完成进程和进程之间的远程连接,每一次连接的性能消耗都是很大的。

如果每一次需要时都重开一个连接,用完后便立马销毁,其代价是非常大的,如果使用连接池便可以减少这种性能消耗。

Hibernate 本身没有提供较佳的数据库连接池实现,其实也没有必要重新造轮子。因为有行业认可的、稳定可靠的第三方数据库连接池可用。
如:

  • DBCP;
  • C3P0;
  • Proxool。

几位都是久经沙场考验、绝对忠诚可靠的老同志。

因为 Hibernate 3.0 后的版本不再支持 DBCP 数据库连接池,DBPC 在此略过不提。但是,不能质疑 DBCP 在行业内的领导性。

本节课就和大家一起讲解在 Hibernate 中使用数据库连接池,让其 Hibernate 的起飞姿势更优雅。

2.1 C3P0

  1. 添加 C3P0 依赖包:

从官网下载的 Hibernate 框架包中已经包含所有的 C3P0 依赖包,可直接添加进去:

  • c3p0-0.9.1.jar;
  • hibernate-c3p0-4.2.0.Final.jar。
  1. 在 Hibernate 的主配置文件中添加如下属性后,便能自动启动 C3P0 连接池的功能。
<property name="connection.url">jdbc:mysql://localhost:3306/myhibernate?useSSL=false</property>
<property name="connection.username">root</property>
<property name="connection.password">abc123</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.provider_class">org.hibernate.service.jdbc.connections.internal.C3P0ConnectionProvider</property>
<property name="hibernate.c3p0.pool_size">5</property>
<property name="hibernate.c3p0.max_size">20</property>
<property name="hibernate.c3p0.min_size">5</property>
<property name="hibernate.c3p0.timeout">120</property>
<property name="hibernate.c3p0.max_statements">100</property>
<property name="hibernate.c3p0.idle_test_period">120</property>
<property name="hibernate.c3p0.testConnectionOnCheckout">true</property>

Hibernate 会把产生连接对象的重担交给 C3P0 。

连接池对象本身会有一些常用的属性,在后面我们再详细讲解。

2.2 Proxool

  1. 添加依赖包:
  • hibernate-proxool-4.2.0.Final.jar;
  • proxool-0.8.3.jar。

Proxool 是 Hibernate 官方指定的数据库连接池,在 Hibernate 的框架包中就包含的有,很容易找到。

  1. 在 Hibernate 的主配置文件中添加:
<property name="hibernate.proxool.pool_alias">ProxoolPool</property>
<property name="hibernate.proxool.xml">proxool.xml</property>
<property name="hibernate.connection.provider_class">org.hibernate.service.jdbc.connections.internal.ProxoolConnectionProvider</property>
<property name="hibernate.proxool.existing_pool">true</property>

proxool 的配置和 C3P0 的配置有点不一样,在主配置文件中告诉 Hibernate 使用 proxool ,但是与 proxool 相关的更多配置信息需要放到特别指定的 proxool.xml 文件中。

所以,需要单独创建一个名为 proxool.xml 的文件,保存在和主配置文件相同的目录下。其内容如下:

Hibernate 4.x 的低版本中使用 proxool 时存在一个没有解决的 bug 。
会抛出 “The url cannot be null” 异常,建议使用 proxool 时,切换高版本 Hibernate 。

当然,除了使用前面介绍的 c3p0 和 proxoolHiberante 还可以通过 JNDI 的方式连接到特定服务器中提供的数据库连接池,有兴趣的话,可以自己研究研究。

3. 数据库连接池的实现原理

在程序的世界,有一个缓存概念,数据库连接池也可以看成是一个缓存池。

企业级的数据库连接池除了要考虑其复用以外,还要考虑并发、性能等诸多因素。实现一个完备的、被行业认定的数据库连接池并不是一件简单轻松的事情。

但如果只是讨论数据库连接池的基本原理,了解其实现过程,倒也不难。

数据库连接池主要解决以下 2 个方面的问题:

  • 不要影响或改变用户使用 connection 连接对象的标准流程。如创建、关闭等正常操作,但是用户在创建或需要连接对象时,不是直接创建,而是从池子里面寻找一个可用的连接对象;
  • 用户使用完连接对象后,在关闭连接对象时,不是真正关闭,而是返回给连接池。

对于连接池本身,需要考虑的问题有:

  • 一个应用程序中,一般只需要一个连接池对象,并保证在整个应用程序中都能访问。所以,连接池对象本身是基于单例设计模式;
  • 实现数据库连接池时,都会有一些基本的参数设置:
public class ConnectionPool implements DataSource {// 最大连接数,一般设置为0表示没有限制private int maxActive;// 最大空闲连接数 ,设 0 表示没有限制private int maxIdle;//连接池中最小空闲连接数private int minIdle;// 初始化连接数目private int initialSize;// 新的请求等待时间private int maxWait;//从没有正确关闭连接的程序中恢复数据库的连接private boolean removeAbandoned;// 活动连接的最大空闲时间,单位为秒private int removeAbandonedTimeout;// 连接池中连接可空闲的时间,单位为毫秒 针对连接池中的连接对象private int minEvictableIdleTimeMillis;private int timeBetweenEvictionRunsMillis;
}

数据库连接池中有一个比较重要的方法,为用户提供连接对象。此方法会使用代理设计模式,为用户提供一个代理对象,既不影响用户的正常使用,又能在用户使用期间进行代码注入。

如下面代码所示:

@Overridepublic Connection getConnection() throws SQLException {return null;}

探讨数据库连接池的实现是一个高级的问题,即使是编写一个比较简单的连接池对象也将涉及到单例设计模式和代理设计模式,也需要创建动态代理对象的相关知识。

本节课还是偏向于从应用层面讲解 Hibernate 中如何使用数据库连接池,更多与连接池有关的深层次内容,有兴趣者可查阅相关资料。

4. 小结

结束往往意味着是一个新的开始。

本节课程和大家讲解了数据库连接池相关的概念,但是,数据库连接池的核心理论知识触及的还远远不够。

本课程通过讲解 Hibernate 使用数据库连接池, 就当是抛砖引玉,这里起一个头,大家有兴趣可以自己研究、探讨。

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

【PostGresql】---- pgSql 将列中合并字符串拆分为多行 实例代码

-- 将 AQY_ID,AQY 中的字符串拆分为多行 SELECT"ID","AQY_ID","AQY",UNNEST ( string_to_array( "AQY_ID", , ) ) AS "AQY_ID_1",UNNEST ( string_to_array( "AQY", , ) ) AS "AQY_1" FROM"JF_SGC…

30.jdk源码阅读之ReentrantReadWriteLock

1.写在前面 ReentrantReadWriteLock 是 Java 并发包中的一个读写锁实现&#xff0c;它允许多个读线程同时访问共享资源&#xff0c;但在写线程访问时&#xff0c;所有的读线程和其他写线程都会被阻塞。不知道大家在日常工作中这个类使用的多不多&#xff0c;对于它的底层实现有…

Tooltip 文字提示

在偶然维护前端开发时,遇到页面列表中某个字段内容太长,且该字段使用了组件显示,导致不能使用纯文本得那个省略号代替显示得css样式效果,如下 所以只能另辟溪路了, 1、最开始想到是使用横向滚动得效果来实现,但是实现后,感觉还是不太理想,因为用户注意不到你这里有滚动…

【基础篇】Docker 容器操作 FOUR

嘿&#xff0c;小伙伴们&#xff01;我是小竹笋&#xff0c;一名热爱创作的工程师。在上一篇文章中&#xff0c;我们探讨了 Docker 镜像管理的相关知识。今天&#xff0c;让我们一起深入了解一下 Docker 容器的操作吧&#xff01; &#x1f4e6; 运行、停止和删除容器 Docker…

一个私有化的中文笔记工具个人知识库,极空间Docker部署中文版『Trilium Notes』

一个私有化的中文笔记工具&个人知识库&#xff0c;极空间Docker部署中文版『Trilium Notes』 哈喽小伙伴们好&#xff0c;我是Stark-C~ 最近被很多小伙伴问到NAS上的笔记工具&#xff0c;虽说之前也出过Memos&#xff0c;刚开始用起来还不错&#xff0c;但是用了一段时间…

【JKI SMO】框架讲解(六)

接JKI SMO 框架讲解&#xff08;五&#xff09;&#xff0c;现在对代码进行一个扩展&#xff0c;当前代码仅有一路电压采集&#xff0c;现在需要扩展一路电流采集通道。 下面是对应的步骤&#xff1a; 1.打开项目&#xff0c;在工具里打开SMO Editor。 2.之前创建的SMO会自动加…

快速收集地图商户信息_百度|高德|腾讯|google

数字化营销中企业名录和商家电话号码的采集已成为营销人员日常工作的首要一环。地图平台以其海量的商家信息和实时更新的特性&#xff0c;成为我们获取数据的宝贵渠道。如何快速利用百度、高德、腾讯这三大地图平台高效采集商家联系方式是每个营销人员的必备技能。 我们整理了…

记录某次“有趣的“挖矿木马排查

挖矿木马是什么&#xff1f; 挖矿木马是一种恶意软件&#xff0c;它在用户不知情或未经同意的情况下&#xff0c;利用受害者的计算机资源进行加密货币挖矿。这类软件通过执行大量运算来挖掘数字货币&#xff0c;如比特币或门罗币等。挖矿木马通常通过漏洞利用、弱口令爆破或非…

微软蓝屏事件:全球网络安全与系统稳定性的警示

文章目录 每日一句正能量前言探讨软件更新流程中的风险管理和质量控制机制软件更新的风险风险管理策略质量控制措施测试流程缺陷识别实施质量控制结论 提供预防类似大规模故障的最佳方案或应急响应对策设计冗余系统实施灾难恢复计划建立高可用架构应急响应对策利用自动化工具和…

豆瓣9.9分!大名鼎鼎的深度学习入门书“鱼书”更新第二版了!带你深刻理解神经网络!

大家应该都知道这本非常有名的著作吧&#xff1a;《深度学习入门&#xff0c;基于python的理论与实现》。 这是更新的第二版&#xff0c;是由日本作者斋藤康毅所著的一本关于深度学习的书籍。这本书的出版社是人民邮电出版社&#xff0c;出品方是图灵教育。这本书的原名是“ゼロ…

vue给数组对象赋值改变对象里面的数据,数据没有更新this.$set

替换数组startTime的值&#xff1a; 原数据 this.serviceTimeList.push({serviceTimeName: 服务时间段,startTime: this.startTime,endTime: this.endTime,currentDateStart: this.currentDate,currentDateEnd: this.currentDate}) this.$set(this.array, index, newValue); …

Day12--Servlet实现前后端交互(案例:学生信息管理系统登录页面)

&#xff08;在一个完整的项目架构中&#xff0c;servlet的角色和位置&#xff09; Servlet、GenericServlet和HttpServlet三者之间的关系是Java Web开发中的一个重要概念&#xff0c;它们共同构成了基于Java的服务器端程序的基础。以下是具体分析&#xff1a; 1. Servlet接口…

AI技术革命对未来就业的影响

一、引言 AI技术革命带来的就业结构变化是双面的&#xff0c;既存在着挑战也蕴含着机遇。过去的几次技术革命例如工业革命和信息技术革命都对就业结构产生了深刻的影响&#xff0c;使一些工作消失&#xff0c;也催生了许多新的工作类型。当前和未来的AI技术发展也必将推动类似…

【HadoopShuffle原理剖析】基础篇二

Shuffle原理剖析 Shuffle&#xff0c;是指对Map输出结果进行分区、排序、合并等处理并交给Reduce的过程。分为Map端的操作和Reduce端的操作。 Shuffle过程 Map端的Shuffle Map的输出结果首先被缓存到内存&#xff0c;当缓存区容量到达80%&#xff08;缓冲区默认100MB&#xff…

基于FPGA的数字信号处理(20)--半加器和全减器

1、前言 既然有半加器和全加器&#xff0c;那自然也有半减器和全减器了。尽管在电路中减法的实现基本都是 补码 加法 的形式&#xff0c;但是正所谓技多不压身&#xff0c;了解一下半减器和全减器还是有一定作用的&#xff0c;至少能扩宽知识面嘛。 2、半减器 最简单的减法器叫…

RFID分体式天线如何选购?

分体式读写器天线具有可与RFID读写器分离部署&#xff0c;在远距离读写、集成应用等场景下拥有十分广泛的应用。下面我们就跟大家一起来了解一下&#xff0c;分体式天线选购的要点有哪些? 分体式天线的选购要点主要包括以下几个方面&#xff1a; 一、明确使用需求 应用场景…

机器学习(五) -- 无监督学习(2) --降维2

系列文章目录及链接 上篇&#xff1a;机器学习&#xff08;五&#xff09; -- 无监督学习&#xff08;2&#xff09; --降维1 下篇&#xff1a; 前言 tips&#xff1a;标题前有“***”的内容为补充内容&#xff0c;是给好奇心重的宝宝看的&#xff0c;可自行跳过。文章内容被…

仪器内部压力不稳定的原因分析

仪器的液路压力波动可能由多种原因引起&#xff0c;具体分析如下&#xff1a; 气泡的影响&#xff1a; 流动相未平衡或柱箱温度不稳定时&#xff0c;容易在色谱柱内产生气泡。泵作用下&#xff0c;流动相中的空气可能会分离出来&#xff0c;留在泵体内排不出去。使用梯度程序时…

vmware 设置ip

要用xshell连接vmware虚拟机&#xff0c;要指定虚拟机的ip地址。 进入虚拟机&#xff0c;用ifconfig命令&#xff0c;看下ip 试了下连接192.168.122.1 连接不上&#xff0c;需要重新设置一个。 1&#xff0c;查看电脑的IP地址 winr,输入cmd&#xff0c;再输入ipconfig 看下本…

Java刷题: 丑数判断

题目 丑数 就是只包含质因数 2、3 和 5 的正整数。 给你一个整数 n &#xff0c;请你判断 n 是否为 丑数 。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 解题思路 我觉得刷题是为了扩宽思考的广度。看到这题的时候&#xff0c;我的大脑是发懵的…