【问题标题】:DBCP Connection Pool leak : Connection.close() don't return the Connection to the pool and the connection is exhaustedDBCP 连接池泄漏:Connection.close() 不将连接返回到池并且连接已用尽
【发布时间】:2012-06-14 03:18:45
【问题描述】:

DBCP 连接池泄漏。

程序返回使用的连接时,连接资源不返回给 游泳池和筋疲力尽!!!

所以,在 maxActive 时间 Connection.close() 中,池在 getConnection() 时挂起。

请告诉我如何解决这个问题!!!

图书馆:

commons-dbcp-1.4.jar commons-pool-1.6.jar mysql-connector-java-5.1.12.jar

Mysql 版本:5.5.9

来源:

import java.sql.Connection;
import java.sql.Driver;
import java.sql.DriverManager;



class ConnectionManager {

    static {

        java.sql.DriverManager.registerDriver((java.sql.Driver) 
                  Class.forName("org.apache.commons.dbcp.PoolingDriver").newInstance()) ;
        java.sql.DriverManager.registerDriver((java.sql.Driver) 
                  Class.forName("com.mysql.jdbc.Driver").newInstance()) ;
   }

   public Connection getConnection(String dataSourceName) {

       return DriverManager.getConnection("jdbc:apache:commons:dbcp:/"+dataSourceName);
   }

}

查询来源::

String dsName = "pool" ;

ConnectionManager pool = new ConnectionManager();

java.sql.Connection conn = pool.getConnection(dsName);


conn.setAutoCommit(true);
if( m_sql.trim().toUpperCase().startsWith("INSERT") )
    pstmt = conn.prepareStatement(m_sql, Statement.RETURN_GENERATED_KEYS);
else
    pstmt = conn.prepareStatement(m_sql);

pstmt.setFetchSize(100);

boolean hasRS = pstmt.execute();

ResultSet resSet = null ;

if (hasRS) {
   resSet = pstmt.getResultSet();

} else {
   resSet = null;
   return ;
}

while(resSet.next()) {

     //resultSet processing ....
     ::::::
}


resSet.close() ;
pstmt.close() ;
conn.close() ;  --> don't return the connection to the pool and exhaust the connection...;;;

:::

poo.jocl :: 这位于 $CLASSPATH

<object class="org.apache.commons.dbcp.DriverManagerConnectionFactory">
    <string value="jdbc:mysql://localhost:3306/db?useUnicode=true&amp;traceProtocol=true&amp;characterEncoding=UTF-8"/>
    <string value="usera"/>
    <string value="passa"/>
</object>

<object class="org.apache.commons.pool.impl.GenericObjectPool">
    <object class="org.apache.commons.pool.PoolableObjectFactory" null="true" />
    <int value="100" /> <!-- maxActive -->
            <byte value="1" /> <!-- whenExhaustedAction -->
    <long value="10000" /> <!-- maxWait -->
    <int value="30" /> <!-- maxIdle -->
    <int value="3" />  <!-- minIdle -->
    <boolean value="true" /> <!-- testOnBorrow -->
    <boolean value="true" />  <!--testOnReturn -->
    <long value="600000" />  <!-- timeBetweenEvictionRunsMillis -->
    <int value="5" />  <!-- numTestsPerEvictionRun -->
    <long value="3600000" /> <!-- minEvictableIdleTimeMillis -->
    <boolean value="true" /> <!-- testWhileIdle -->
</object>

<object class="org.apache.commons.pool.KeyedObjectPoolFactory" null="true"/>    
<string null="true"/>   
<boolean value="false"/>
<boolean value="true"/>

【问题讨论】:

    标签: mysql jdbc connection connection-pooling


    【解决方案1】:

    由于注册了 MySQL 驱动程序,您可能没有使用 Apache 连接池。尝试删除它。从 JDBC 4.0 开始,您当然根本不需要注册 MySQL 驱动程序。事实上,由于所有的 XML 配置,我认为您根本不需要那个静态块。尝试删除它。

    【讨论】:

    • 是的,你是对的。 MySQL驱动不需要注册!!!但是,删除它,程序也会挂起......;;;
    • 我不知道为什么程序直接使用MySQL驱动而不是Apache连接池尽管删除了注册MySQL驱动。
    • 哎呀!!!。我在我的项目源中犯了一个错误......上面的源是好的。当我在我的库中使用更新查询例程时。我错过了关闭()。好傻……;;;感谢 EJP。你说得对。 MySql 驱动程序不需要注册。 staic 例程是为了不每次都调用 getConnection() !!!
    猜你喜欢
    • 2015-03-28
    • 1970-01-01
    • 2019-03-03
    • 2012-12-22
    • 1970-01-01
    • 2017-02-15
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多