java数据库连接池 dbcp 的用法

  1. 本文转自:http://www.iteye.com/topic/151132

  2. 需要下commons-dbcp  commons-pool 这两个jar包

  3. import org.apache.commons.dbcp.BasicDataSource;  
  4. import org.apache.commons.dbcp.BasicDataSourceFactory;  
  5.   
  6. import java.sql.SQLException;  
  7. import java.sql.Connection;  
  8. import java.util.Properties;  
  9.   
  10. public class ConnectionSource {  
  11.     private static BasicDataSource dataSource = null;  
  12.   
  13.     public ConnectionSource() {  
  14.     }  
  15.   
  16.     public static void init() {  
  17.   
  18.         if (dataSource != null) {  
  19.             try {  
  20.                 dataSource.close();  
  21.             } catch (Exception e) {  
  22.                 //  
  23.             }  
  24.             dataSource = null;  
  25.         }  
  26.   
  27.         try {  
  28.             Properties p = new Properties();  
  29.             p.setProperty("driverClassName""oracle.jdbc.driver.OracleDriver");  
  30.             p.setProperty("url""jdbc:oracle:thin:@192.168.0.1:1521:testDB");  
  31.             p.setProperty("password""scott");  
  32.             p.setProperty("username""tiger");  
  33.             p.setProperty("maxActive""30");  
  34.             p.setProperty("maxIdle""10");  
  35.             p.setProperty("maxWait""1000");  
  36.             p.setProperty("removeAbandoned""false");  
  37.             p.setProperty("removeAbandonedTimeout""120");  
  38.             p.setProperty("testOnBorrow""true");  
  39.             p.setProperty("logAbandoned""true");  
  40.   
  41.             dataSource = (BasicDataSource) BasicDataSourceFactory.createDataSource(p);  
  42.   
  43.         } catch (Exception e) {  
  44.             //  
  45.         }  
  46.     }  
  47.   
  48.   
  49.     public static synchronized Connection getConnection() throws  SQLException {  
  50.         if (dataSource == null) {  
  51.             init();  
  52.         }  
  53.         Connection conn = null;  
  54.         if (dataSource != null) {  
  55.             conn = dataSource.getConnection();  
  56.         }  
  57.         return conn;  
  58.     }  
  59. }  
接下来,在我们的应用中,只要简单地使用ConnectionSource.getConnection()就可以取得连接池中的数据库连接,享受数据库连接带给我们的好处了。当我们使用完取得的数据库连接后,只要简单地使用connection.close()就可把此连接返回到连接池中,至于为什么不是直接关闭此连接,而是返回给连接池,这是因为dbcp使用委派模型来实现Connection接口了。 

      在使用Properties来创建BasicDataSource时,有很多参数可以设置,比较重要的还有: 

     testOnBorrow、testOnReturn、testWhileIdle,他们的意思是当是取得连接、返回连接或连接空闲时是否进行有效性验证(即是否还和数据库连通的),默认都为false。所以当数据库连接因为某种原因断掉后,再从连接池中取得的连接,实际上可能是无效的连接了,所以,为了确保取得的连接是有效的, 可以把把这些属性设为true。当进行校验时,需要另一个参数:validationQuery,对oracle来说,可以是:SELECT COUNT(*) FROM DUAL,实际上就是个简单的SQL语句,验证时,就是把这个SQL语句在数据库上跑一下而已,如果连接正常的,当然就有结果返回了。 

      还有2个参数:timeBetweenEvictionRunsMillis 和 minEvictableIdleTimeMillis, 他们两个配合,可以持续更新连接池中的连接对象,当timeBetweenEvictionRunsMillis 大于0时,每过timeBetweenEvictionRunsMillis 时间,就会启动一个线程,校验连接池中闲置时间超过minEvictableIdleTimeMillis的连接对象。

你可能感兴趣的:(java,数据库,连接池)