众所周知,无论现在是B/S或者是C/S应用中,都免不了要和数据库打交道。在与数据库交
互过程中,往往需要大量的连接。对于一个大型应用来说,往往需要应对数以千万级的用户连
接请求,如果高效相应用户请求,对应用开发者而言是一个很重要的问题。下面就我所接触到
的解决方法分享给大家。
学过计算机网络的都知道,在一个内部局域网中,大部分用的都是私有地址,要想和外部
打交道,必须要有相应的合法外部地址相对应。然而内部用户数量巨大,一台机子一个外部IP
是不现实的。这样就有了一种叫做连接池的概念。因为不是每一个用户都要同时上网,当一个
用户需要上网的时候,他就可以从连接池中取得一个外部IP地址,从而对外网进行访问。当这
个用户不再需要上网的时候,这一个IP地址被放回连接池中,又可以给其他的用户访问。这里
的连接池是主要是为了解决IP地址数量问题的。而在数据库中,也有连接池的概念。我觉得这
个连接池主要是通过对连接的复用,从而更加高效的实现了对用户请求的响应。常见的供java
开发的连接池主要有DBCP和c3p0,当然在了解了连接池的原理后,用户也可以开发并创建自
己连接池。
数据库连接池的原理:可以参考这篇文章,不再赘述。。
http://www.kuqin.com/database/20080903/16384.html
下面主要通过两个例子描述下DBCP和c3p0的使用,同时给以比较。
1 DBCP。
DBCP是 apache 上的一个 java 连接池项目,也是 tomcat 使用的连接池组件。单独使
用DBCP需要3个包:common-dbcp.jar,common-pool.jar,common-collections.jar.
public class DBCPUtils {
private static DBCPUtils dbcputils=null;
private BasicDataSource bds=null;
private DataSourceConnectionFactory dscf=null;
private DBCPUtils(){
if(bds==null)
bds=new BasicDataSource();
bds.setUrl(DBConsts.url);
bds.setUsername(DBConsts.username);
bds.setPassword(DBConsts.password);
bds.setDriverClassName(DBConsts.driverclass);
bds.setMaxActive(100);
bds.setInitialSize(20);
bds.setMaxIdle(20);
bds.setMinIdle(10);
dscf=new DataSourceConnectionFactory(bds);
}
public synchronized static DBCPUtils getInstance(){
if(dbcputils==null)
dbcputils=new DBCPUtils();
return dbcputils;
}
public Connection getConnection(){
Connection con=null;
try {
con=(Connection)dscf.createConnection();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return con;
}
public static void main(String[] args) throws SQLException {
Connection con=null;
long begin=System.currentTimeMillis();
for(int i=0;i<1000000;i++){
con=DBCPUtils.getInstance().getConnection();
con.close();
}
long end=System.currentTimeMillis();
System.out.println("耗时为:"+(end-begin)+"ms");
}
}
结果为 :耗时为:2078ms
2 C3P0。
C3P0是一个开放源代码的JDBC连接池,它在lib目录中与Hibernate一起发布,包括了实现
jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSources 对象。在使用时
需要导入c3p0-*.jar包。
public class C3P0Utils {
private static C3P0Utils dbcputils=null;
private ComboPooledDataSource cpds=null;
private C3P0Utils(){
if(cpds==null){
cpds=new ComboPooledDataSource();
}
cpds.setUser(DBConsts.username);
cpds.setPassword(DBConsts.password);
cpds.setJdbcUrl(DBConsts.url);
try {
cpds.setDriverClass(DBConsts.driverclass);
} catch (PropertyVetoException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
cpds.setInitialPoolSize(100);
cpds.setMaxIdleTime(20);
cpds.setMaxPoolSize(100);
cpds.setMinPoolSize(10);
}
public synchronized static C3P0Utils getInstance(){
if(dbcputils==null)
dbcputils=new C3P0Utils();
return dbcputils;
}
public Connection getConnection(){
Connection con=null;
try {
con=cpds.getConnection();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return con;
}
public static void main(String[] args) throws SQLException {
Connection con=null;
long begin=System.currentTimeMillis();
for(int i=0;i<1000000;i++){
con=C3P0Utils.getInstance().getConnection();
con.close();
}
long end=System.currentTimeMillis();
System.out.println("耗时为:"+(end-begin)+"ms");
}
}
结果为 :耗时为:26094ms
此类为连接数据的常量值。
public class DBConsts {
public static final String url="jdbc:mysql://localhost:3306/deys";
public static final String username="root";
public static final String password="";
public static final String driverclass="com.mysql.jdbc.Driver";
}
通过以上两个程序可见,DBCP有着比C3P0更高的效率,但是实际应用中,DBCP可能出现丢失
连接的可能,而C3P0稳定性较高。因此在实际应用中,C3P0使用较为广泛。
分享到:
相关推荐
"数据库连接池dbcp和c3p0jar包"这个压缩包包含了这两个库的JAR文件,开发者可以解压并导入到自己的项目中,然后通过简单的代码配置来启用数据库连接池服务。例如,使用Spring框架,可以在配置文件中声明数据源,指定...
本文主要探讨了三个常用的数据库连接池:DBCP、c3p0和Druid,以及它们的配置说明。 1. **DBCP(Apache Commons DBCP)** DBCP是Apache Commons项目的一部分,它依赖于Apache Commons Pool对象池机制来管理数据库...
DBCP(Jakarta DBCP)和C3P0是两种常用的数据库连接池实现,它们在提高应用程序效率、优化数据库资源使用方面起到了重要作用。 **DBCP(Jakarta DBCP)** DBCP是Apache软件基金会的一个项目,全称为Jakarta ...
Apache DBCP(Database Connection Pool)和C3P0都是流行的开源数据库连接池实现。 - **DBCP**:Apache DBCP是Apache Commons Pool项目中的一个子项目,它提供了对数据库连接池的实现。 - **C3P0**:C3P0(Concise ...
本文将深入探讨数据库连接池的基础知识,特别是关于DBCP(Jakarta Commons DBCP)和C3P0两个流行的连接池实现。 首先,让我们了解什么是数据库连接池。数据库连接池是在应用服务器启动时创建的一组预定义的数据库...
相比其他流行的数据库连接池,如DBCP、HikariCP、Druid等,c3p0在某些方面可能稍显落后,例如性能和内存占用。但其丰富的配置选项和良好的兼容性仍使其在某些场景下成为不错的选择。例如,对于小型项目或对性能要求...
数据库连接池(DBCP)是Java应用中用于管理数据库连接的一种技术,它允许应用程序重复使用已建立的数据库连接,而不是每次需要访问数据库时都创建新的连接。这样可以显著提高应用程序的性能,减少系统资源的消耗,并...
同时,DBCP2相比其他数据库连接池,如C3P0、HikariCP等,可能在性能和稳定性方面稍逊一筹,因此在选择时应根据项目需求进行权衡。 总的来说,DBCP2是一个适用于学习和小型项目的数据库连接池实现,对于初学者来说,...
本资源包包含三个主流的数据库连接池实现:c3p0、dbcp和Druid。它们各有特点,适应不同的应用场景。 1. **c3p0**:全称为Com形3P0,是由Miquel Arquero开发的一个开源的JDBC连接池。c3p0提供了完善的连接池管理和...
开源数据库连接池DBCP,全称为Jakarta-Commons-DBCP,是Apache软件基金会Jakarta项目中的一个组件,主要用于解决Java应用程序与数据库之间的连接管理问题。DBCP提供了一个高效且可配置的数据库连接池,使得多个...
本示例将详细介绍如何使用DBCP(Database Connection Pool)、c3p0以及Tomcat内置的数据源来实现数据库连接池的配置与使用。 **DBCP(Database Connection Pool)** DBCP是Apache软件基金会的Jakarta项目下的一个子...
DBCP(Jakarta DBCP)和c3p0是两种常用的开源数据库连接池实现。 DBCP,全称Jakarta Commons DBCP,是Apache软件基金会下的一个项目,它基于Apache的Jakarta POI项目中的DBUtils模块发展而来。DBCP提供了一个可配置...
c3p0和DBCP(BasicDataSource)是两个广泛应用的开源数据库连接池实现。 c3p0是一个完全开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。c3p0-0.9.5.2.jar包含了c3p0的运行时库,而...
在实际应用中,开发人员可以根据需求选择使用DBCP或C3P0,或者与其他数据库连接池库如HikariCP、Druid等结合。这些库通常通过JDBC API与各种数据库进行交互,因此它们可以与多种数据库管理系统兼容,如MySQL、Oracle...
**c3p0数据库连接池详解** c3p0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。c3p0的主要功能是管理数据库连接,通过复用已存在的连接来提高数据库访问效率,减少系统资源...
在本压缩包“数据库连接池C3P0.zip”中,包含了C3P0数据库连接池的相关jar包以及配置文件,用于帮助开发者集成到他们的Java应用中,特别是与MYSQL数据库配合使用。 C3P0的主要特性包括: 1. **连接池管理**:C3P0...
- **commons-pool**:Apache Commons Pool是通用的对象池服务,可以用于创建各种资源的池化,包括C3P0在内的数据库连接池在底层使用了这个库来实现对象的管理和复用。 在实际开发中,你通常会将这些JAR包添加到项目...
**数据库连接池(DBCP)** 是一个在Java应用程序中管理数据库连接的工具,它能够有效地提高数据库操作的性能和效率。...理解和掌握DBCP的使用和配置,对于理解数据库连接池的工作原理和提升应用性能具有重要意义。
C3P0是一个开源的Java数据库连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。在Java应用程序中,数据库连接池扮演着非常重要的角色,它能够有效地管理数据库连接,提高系统性能,减少数据库资源...