dbcp与c3p0的区别

众所周知,不管如今是B/S或者是C/S应用中,都免不了要和数据库打交道。在与数据库交 互过程当中,每每须要大量的链接。对于一个大型应用来讲,每每须要应对数以千万级的用户连
接请求,若是高效相应用户请求,对应用开发者而言是一个很重要的问题。下面就我所接触到 的解决方法分享给你们。 
   学过计算机网络的都知道,在一个内部局域网中,大部分用的都是私有地址,要想和外部 打交道,必需要有相应的合法外部地址相对应。然而内部用户数量巨大,一台机子一个外部IP 
是不现实的。这样就有了一种叫作链接池的概念。由于不是每个用户都要同时上网,当一个 用户须要上网的时候,他就能够从链接池中取得一个外部IP地址,从而对外网进行访问。当这 个用户再也不须要上网的时候,这一个IP地址被放回链接池中,又能够给其余的用户访问。这里 的链接池是主要是为了解决IP地址数量问题的。而在数据库中,也有链接池的概念。我以为这 个链接池主要是经过对链接的复用,从而更加高效的实现了对用户请求的响应。常见的供java 开发的链接池主要有DBCP和c3p0,固然在了解了链接池的原理后,用户也能够开发并建立自 己链接池。 
    数据库链接池的原理:能够参考这篇文章,再也不赘述。。 
    http://www.kuqin.com/database/20080903/16384.html 
    下面主要经过两个例子描述下DBCP和c3p0的使用,同时给以比较。  html


1 DBCP。 
   DBCP是 apache 上的一个 java 链接池项目,也是 tomcat 使用的链接池组件。单独使 

用DBCP须要3个包:common-dbcp.jar,common-pool.jar,common-collections.jar. java

复制代码
  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");
    }
}
复制代码

 

 

经过以上两个程序可见,DBCP有着比C3P0更高的效率,可是实际应用中,DBCP可能出现丢失 

链接的可能,而C3P0稳定性较高。所以在实际应用中,C3P0使用较为普遍apache

相关文章
相关标签/搜索