hibernate数据库连接池配置

本文介绍了数据库连接池的基本概念及配置方法,包括hibernate自带连接池、第三方连接池c3p0与proxool的使用。重点讲解了如何通过配置参数调整连接池的性能,以提高应用程序的稳定性和响应速度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据库连接池配置

1.hibernate自带的连接池(算法不成熟)
2.使用配置文件指定到连接池(第三方包提供的连接池,如c3p0,proxool)
3.从容器中获取得到的连接池
出于性能与稳定性,移植性的考虑应该使用第三方包的连接池。


连接池是一块用于存放连接对象session的内存空间。在进行数据库操作时,最消耗内存资源的是连接的创建。使用容器中获取得到的连接池,

在容器启动时创建连接。而使用第三方包是在第一次连接时创建数据库连接对象。当有用户使用一个连接对象时,连接对象被标示为忙碌状态

,其他用户可以获得一个空闲的连接对象。我们需要手动设置一个连接到空闲状态,session.close()这是并不是关闭连接,而是设置这个连接

对象为空闲状态。
连接池有最大和最小连接对象的设置。当一个连接被创建之后在一定的空闲时间之后会被关闭。最小连接数是设置,连接池最少有几个连接是

不被关闭的。最大连接数是设置最多连接池中可以有几个连接对象同时存在。在达到这个最大数时,并且所有的连接对象都是处于忙碌状态时
,另一个用户的数据操作将处于等待中。time_out设置了等待的最长时间。
min,max需要根据具体的访问情况来设置。还有服务器的情况也有影响。

第三方JAR包
1)c3p0

hibernate自带支持c3p0连接池,不需要额外的配置文件.

hibernate.cfg
hibernate.cspo.min_size
hibernate.cspo.max_size
hibernate.cspo.time_out
hibernate.cspo.max_statement

2)proxool成熟的第三方包.
需要单独的配置文件proxool.xml
Hibernate.cfg.xml配置

<!-- Proxool -->
<property name="proxool.xml">proxool.xml</property>
<property name="proxool.pool_alias">sqlserver</property>
<property name="hibernate.connection.driver_class">
org.hibernate.connection.ProxoolConnectionProvider
</property>

proxool配置文件


***************************proxool.xml***************************
<?xml version="1.0" encoding="UTF-8"?>
<proxool>
<!-- SQL Server -->
<alias>sqlserver</alias>
<driver-url>jdbc:jtds:sqlserver://127.0.0.1:1433/master</driver-url>
<driver-class>net.sourceforge.jtds.jdbc.Driver</driver-class>
<driver-properties>
<property name="user" value="sa"/>
<property name="password" value=""/>
</driver-properties>

<!-- Oracle
<alias>oracle</alias>
<driver-url>jdbc:oracle:thin:@127.0.0.1:1521:myoracle</driver-url>
<driver-class>oracle.jdbc.driver.OracleDriver</driver-class>
<driver-properties>
<property name="user" value="sa"/>
<property name="password" value="sa"/>
</driver-properties>
-->

<maximum-active-time>5</maximum-active-time>
<minimum-connection-count>10</minimum-connection-count>
<maximum-connection-count>50</maximum-connection-count>
<!--测试连接是否通畅-->
<house-keeping-test-sql>select CURRENT_DATE</house-keeping-test-sql>
</proxool>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值