标签:数据库连接池 hibernate 开源 jdbc
现在常用的开源数据库连接池主要有c3p0、dbcp、proxool三种,其中:
Spring 推荐使用dbcp;
Hibernate 推荐使用c3p0和proxool;
1、 DBCP:Apache
DBCP(DataBase connection pool)数据库连接池。是Apache上的一个 java连接池项目,也是 tomcat使用的连接池组件。单独使用dbcp需要3个包:common-dbcp.jar,common-pool.jar,common-collections.jar由于建立数据库连接是一个非常耗时耗资源的行为,所以通过连接池预先同数据库建立一些连接,放在内存中,应用程序需要建立数据库连接时直接到连接池中申请一个就行,用完后再放回去。dbcp没有自动的去回收空闲连接的功能。
2、 C3P0:
C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能。目前使用它的开源项目有Hibernate,Spring等。c3p0有自动回收空闲连接功能。
3、 Proxool:Sourceforge
Proxool是一种Java数据库连接池技术。是sourceforge下的一个开源项目,这个项目提供一个健壮、易用的连接池,最为关键的是这个连接池提供监控的功能,方便易用,便于发现连接泄漏的情况。
对比:
1> 相同时间内同等量的线程数和循环次数下:通过对三个连接池的三个标志性性能测试参数(Average,median,90%Line)进行比较发现:性能dbcp<=c3p0<proxool;
2> 不同情况下的同一数据库连接池测试:通过观察 Average,median,90%Line三个参数发
现三个连接池的稳定性(三种连接池的三个测试参数的变化情况)依次:稳定性dbcp>=c3p0>proxool。
结论:
通过对三种数据库连接池的性能测试发现,proxool和 c3p0能够更好的支持高并发,但是在稳定性方面略逊于 dpcp;
各种连接池的配置:
未配置连接池的情况:
-
<?xml version="1.0" encoding="UTF-8"?>
-
<beans xmlns="http://www.springframework.org/schema/beans"
-
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
-
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
-
xmlns:jee="http://www.springframework.org/schema/jee"
-
xsi:schemaLocation="http:
-
http:
-
http:
-
http:
-
http:
-
http:
-
http:
-
<context:property-placeholder location="classpath:jdbc_config.properties"/>
-
<!--
-
DriverManagerDataSource:在每个连接请求时新建一个连接。
-
SingleConnectionDataSource:在每个连接请求时都返回同一连接。
-
-->
-
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
-
<property name="driverClassName" value="${driverClassName}"/>
-
<property name="url" value="${url}"/>
-
<property name="username" value="${username}"/>
-
<property name="password" value="${password}"/>
-
</bean>
-
</beans>
配置DBCP
-
<context:property-placeholder location="classpath:dbcp_config.properties" />
-
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
-
destroy-method="close">
-
<property name="driverClassName" value="${driverClassName}"/>
-
<property name="url" value="${url}"/>
-
<property name="username" value="${username}"/>
-
<property name="password" value="${password}"/>
-
<property name="initialSize" value="${initialSize}"/>
-
<property name="maxActive" value="${maxActive}"/>
-
<property name="maxIdle" value="${maxIdle}"/>
-
<property name="minIdle" value="${minIdle}"/>
-
<property name="maxWait" value="${maxWait}"/>
-
<property name="defaultAutoCommit" value="${defaultAutoCommit}"/>
-
</bean>
-
配置C3p0
-
<context:property-placeholder location="classpath:c3p0_config.properties"/>
-
<bean id="dataSource"
-
class="com.mchange.v2.c3p0.ComboPooledDataSource">
-
<property name="user" value="${user}"/>
-
<property name="password" value="${password}"/>
-
<property name="jdbcUrl" value="${jdbcUrl}"/>
-
<property name="driverClass" value="${driverClass}"/>
-
-
<property name="checkoutTimeout" value="${checkoutTimeout}"/>
-
<property name="idleConnectionTestPeriod" value="${idleConnectionTestPeriod}"/>
-
<property name="initialPoolSize" value="${initialPoolSize}"/>
-
<property name="maxIdleTime" value="${maxIdleTime}"/>
-
-
<property name="maxPoolSize" value="${maxPoolSize}"/>
-
<property name="minPoolSize" value="${minPoolSize}"/>
-
<property name="maxStatements" value="${maxStatements}"/>
-
</bean>
-
配置jndi
-
-
<!--
-
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean"
-
scope="singleton">
-
<property name="jndiName" value="/jdbc/spring-jndi" />
-
< !--
-
当resourceRef 属性为true时,jndiName会被添加java:comp/env/,从应用服务器的JNDI目录获取数据源
-
-- >
-
<property name="resourceRef" ref="true" />
-
</bean>
-
-->
-
<!-- jee 命名空间里的jee:jndi-lookup 元素可以从jndi获取对象。下面的XML等效于前面对JndiObjectFactoryBean的明确声明 -->
-
<jee:jndi-lookup id="dataSource" jndi-name="/jdbc/spring-jndi" resource-ref="true"/>
-
测试使用一下
-
<import resource="classpath:bean-dbcp.xml" />
-
<bean id="helloJdbcDao" class="cn.partner4java.jdbc.impl.HelloJdbcDaoBean">
-
<property name="dataSource" ref="dataSource"/>
-
</bean>
-
。。。。。。
-
package cn.partner4java.jdbc;
-
import java.sql.Connection;
-
import java.sql.SQLException;
-
-
-
-
-
-
public interface HelloJdbcDao
{
-
public Connection
getConnection() throws SQLException;
-
}
-
。。。。。。
-
package cn.partner4java.jdbc.impl;
-
import java.sql.Connection;
-
import java.sql.SQLException;
-
import javax.sql.DataSource;
-
import cn.partner4java.jdbc.HelloJdbcDao;
-
-
-
-
-
-
public class HelloJdbcDaoBean implements HelloJdbcDao{
-
public DataSource
dataSource;
-
public void setDataSource(DataSource
dataSource) {
-
this.dataSource
= dataSource;
-
}
-
public Connection
getConnection() throws SQLException
{
-
return dataSource.getConnection();
-
}
-
-
}
-
。。。。。
-
package cn.partner4java.jdbc.junit;
-
import java.sql.SQLException;
-
import org.springframework.context.ApplicationContext;
-
import org.springframework.context.support.ClassPathXmlApplicationContext;
-
import cn.partner4java.jdbc.HelloJdbcDao;
-
import junit.framework.TestCase;
-
public class HelloJdbcDaoBeanTest extends TestCase
{
-
public HelloJdbcDao
helloJdbcDao;
-
@Override
-
protected void setUp() throws Exception
{
-
ApplicationContext ac = new ClassPathXmlApplicationContext("beans-jdbc.xml");
-
helloJdbcDao = (HelloJdbcDao) ac.getBean("helloJdbcDao");
-
}
-
-
public void testGetConn() throws SQLException{
-
System.out.println(helloJdbcDao.getConnection());
-
}
-
-
}
-
Spring整合HIbernate时,三种数据库连接池的配置和比较,布布扣,bubuko.com
Spring整合HIbernate时,三种数据库连接池的配置和比较
标签:数据库连接池 hibernate 开源 jdbc
原文地址:http://blog.csdn.net/he90227/article/details/36006429