org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot get a connection, pool error Timeout waiting
2015-11-12 13:18
766 查看
在使用tomcat的JNDI配置数据库连接时,如果没有使用想proxool,池c3p0这样的连接池组件时,tomcat将默认使用tomcat容器内建的DHCP连接池组建。
我的jndi配置如下
<Resource
name="jdbc/NEWDB"
type="javax.sql.DataSource"
username="APDEV"
password="123456"
driverClassName="net.sourceforge.jtds.jdbcx.JtdsDataSource"
maxIdle="2"
maxWait="5000"
url="jdbc:jtds:sqlserver://172.18.127.129:1433/NEWDB"
maxActive="4"
/>
为了在开发阶段尽可能的暴露是否存在连接未完全释放的问题,将maxActive和maxIdle参数都设置的比较小。
有一种情况就是,如果某个页面存在大量的数据库查询操作(例如:此页面加载时将要建立4个connection),那么当我在此页面频繁的刷新页面时,将会抛出异常
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot get a connection, pool error Timeout waiting for idle object
经过调查发现,抛出此异常的原因为连接池泄漏,也就是再也无法从连接池中获取有效的数据库连接。
频繁的刷新页面导致上一次获取的connection还没有得到有效释放,下一次的connection请求已经到达,如是刷新多次后导致池资源耗尽,即所谓的连接池泄漏。
而且,在此种情况下,最糟糕的是异常发生后导致整个服务向连接池发起connection请求都将一直抛出如上异常,无法恢复到正常状态。服务宕机,必须重启tomcat才能恢复,这真是个可怕的事情。
我的jndi配置如下
<Resource
name="jdbc/NEWDB"
type="javax.sql.DataSource"
username="APDEV"
password="123456"
driverClassName="net.sourceforge.jtds.jdbcx.JtdsDataSource"
maxIdle="2"
maxWait="5000"
url="jdbc:jtds:sqlserver://172.18.127.129:1433/NEWDB"
maxActive="4"
/>
为了在开发阶段尽可能的暴露是否存在连接未完全释放的问题,将maxActive和maxIdle参数都设置的比较小。
有一种情况就是,如果某个页面存在大量的数据库查询操作(例如:此页面加载时将要建立4个connection),那么当我在此页面频繁的刷新页面时,将会抛出异常
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot get a connection, pool error Timeout waiting for idle object
经过调查发现,抛出此异常的原因为连接池泄漏,也就是再也无法从连接池中获取有效的数据库连接。
频繁的刷新页面导致上一次获取的connection还没有得到有效释放,下一次的connection请求已经到达,如是刷新多次后导致池资源耗尽,即所谓的连接池泄漏。
而且,在此种情况下,最糟糕的是异常发生后导致整个服务向连接池发起connection请求都将一直抛出如上异常,无法恢复到正常状态。服务宕机,必须重启tomcat才能恢复,这真是个可怕的事情。
相关文章推荐
- tomcat 直接localhost:8080访问项目
- jeesite部署到Tomcat后,无法访问,cannot be resolved in either web.xml or the jar files deployed with this application
- 配置Tomcat时server.xml和content.xml自动还原问题
- 前端nginx时,让后端tomcat记录真实IP
- tomcat配置文件server.xml详解
- 钻一钻Tomcat 之 Tomcat安装版(Ⅱ)
- tomcat远程调试参数
- 钻一钻Tomcat 之 tomcat知多少(Ⅰ)
- Linux下如何查看tomcat是否启动/系统日志等
- Eclipse集成Tomcat访问报错404
- Centos6.5设置Tomcat7管理员用户名和密码
- 整合apache和tomcat构建Web服务器
- 一键解决从Myeclipse工程打包JavaWeb项目到服务器的Tomcat,并自动部署
- 浅谈WebLogic和Tomcat
- Tomcat安装配置
- nginx+tomcat集群高可用
- Could not publish server configuration for Tomcat v6.0 Server at localhost.
- tomcat内存不足,一段时间后不响应了
- Tomcat
- mysql+tomcat连接池配置