关于Cannot get a connection, pool exhausted解决办法

    技术2022-05-19  21

    近做了一个项目用的是连接池(Tomcat+oracle),调试程序的过程中发现,运行一段时间后就会出现 Cannot get a connection, pool exhausted这样的异常。其实这个问题很简单就是数据库connection对象用尽了。

    解决的办法有3个

    1重启你的服务器

    2在content.xml中,将maxActive设置为零,或者调高它的值

    3在你的程序中正确关闭connections 这里有一点要注意要把关闭的语句写在finally中,如果你写在try{}中出现异常的话是无法正确关闭的。

    要象这样

    } catch (SQLException e) {  /** Exception handling **/  } finally {  try {  if (stmt != null)  stmt.close();  if (dbConnection != null)  dbConnection.close();  } catch (SQLException e) {  /** Exception handling **/  }  }  当然这3个方法里前两个并不能从根本上解决你的问题,所以还是要好好研究你的程序,一定要将用完的connection放回到池中。

    如果还有什么不明白的可以联系我qq:123748464 也许我可以帮助你

    1 问题描述 Web程序在tomcat刚开始运行时速度很快,但过一段时间后发现速度变得很慢。 检查日志输出,发现异常如下: org.apache.commons.dbcp.SQLNestedException: Cannot get a connection, pool exhausted, cause:  java.util.NoSuchElementException: Timeout waiting for idle object 同时在SQLServer事件探查器中发现,每执行一次sql语句都要产生Audit login事件,语句执行后产生 Audit logout事件。说明每一次tomcat都是重新打开新的连接。 2 问题解决 tomcat 的数据源定义提供了三个参数: a. 如果设为true则tomcat自动检查恢复重新利用,没有正常关闭的Connection.(默认是false) <parameter> <name>removeAbandoned</name> <value>true</value> </parameter> b. 设定连接在多少秒内被认为是放弃的连接,即可进行恢复利用。 <parameter> <name>removeAbandonedTimeout</name> <value>60</value> </parameter> c. 输出回收的日志,可以详细打印出异常从而发现是在那里发生了泄漏 <parameter> <name>logAbandoned</name> <value>true</value> </parameter>


    最新回复(0)