使用druid连接池的超时回收机制排查连接泄露问题

简介:

在工程中使用了druid连接池,运行一段时间后系统出现异常:

 


 
  1. Caused by: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60009, active 50  
  2.                 at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:80)  
  3.                 at org.springframework.jdbc.support.JdbcUtils.extractDatabaseMetaData(JdbcUtils.java:280)  
  4.                 ... 64 more  
  5. Caused by: com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60000, active 50  
  6.                 at com.alibaba.druid.pool.DruidDataSource.getConnectionInternal(DruidDataSource.java:1071)  
  7.                 at com.alibaba.druid.pool.DruidDataSource.getConnectionDirect(DruidDataSource.java:898)  
  8.                 at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4544)  


mysql数据库最大连接数设置为500,使用客户端能正常连接。连接数被未被占满。

 

 

分析原因应该是程序中有地方连接未关闭造成的。那如何来定呢?使用druid连接池的超时回收机制,在配置中增加以下内容:

 


 
  1. <!-- 超过时间限制是否回收 -->  
  2. <property name="removeAbandoned" value="true" />  
  3. <!-- 超时时间;单位为秒。180秒=3分钟 -->  
  4. <property name="removeAbandonedTimeout" value="180" />  
  5. <!-- 关闭abanded连接时输出错误日志 -->  
  6. <property name="logAbandoned" value="true" />     


运行程序,当连接超过3分钟后会强制进行回收,并输出异常日志。

 

 


 
  1. 2014-10-13 16:02:28,919 ERROR [com.alibaba.druid.pool.DruidDataSource] - <abandon connection, open stackTrace  
  2.         at java.lang.Thread.getStackTrace(Thread.java:1567)  
  3.         at com.alibaba.druid.pool.DruidDataSource.getConnectionDirect(DruidDataSource.java:995)  
  4.         at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4544)  
  5.         at com.alibaba.druid.filter.stat.StatFilter.dataSource_getConnection(StatFilter.java:661)  
  6.         at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4540)  
  7.         at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:919)  
  8.         at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:911)  
  9.         at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:98)  
  10.           
  11.         at cn.org.xxx.xxx.xxx.PaginationInterceptor.intercept(PaginationInterceptor.java:96)  
  12.           
  13.         at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:60)  
  14.         at com.sun.proxy.$Proxy59.query(Unknown Source)  
  15.         at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:108)  

 


很清楚地看到是在哪里打开的连接未关闭一直在占有。

 

 

此配置项会影响性能,只在排查的时候打开。系统运行时最好关闭。

标签:  JAVA连接池

本文转自 netcorner 博客园博客,原文链接:http://www.cnblogs.com/netcorner/p/4380949.html    ,如需转载请自行联系原作者

相关文章
|
Arthas druid Java
一次druid数据库连接池连接泄露的排查分析
一次druid数据库连接池连接泄露的排查分析
1323 1
|
监控 druid Java
监控druid数据库连接池连接泄露的思路
监控druid数据库连接池连接泄露的思路
1192 2
|
druid 前端开发 关系型数据库
mysql使用druid时自动断开连接解决方案
mysql使用druid时自动断开连接解决方案
265 0
|
22天前
|
网络协议 Java Linux
如何解决“连接超时”的问题
当遇到“连接超时”问题时,可尝试以下方法:检查网络连接、重启路由器、清除浏览器缓存、关闭防火墙或杀毒软件、更改DNS服务器等。若问题依旧,建议联系网络服务提供商或技术人员寻求帮助。
|
28天前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
44 3
|
28天前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
27 1
|
5月前
|
SQL druid Java
线程池相关故障问题之Druid数据库连接池中,为何需要设置TransactionTimeout
线程池相关故障问题之Druid数据库连接池中,为何需要设置TransactionTimeout
139 0
|
28天前
|
Java 数据库连接 数据库
Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销
本文深入探讨了Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销,显著提升了系统的响应速度和吞吐量。文章介绍了连接池的工作原理,并以HikariCP为例,展示了如何在Java应用中使用连接池。通过合理配置和优化,连接池技术能够有效提升应用性能。
42 1
|
7月前
|
监控 druid Java
连接池的监控和管理
连接池的监控和管理
|
SQL 监控 Java
如何避免JDBC池和内存溢出?优化策略大揭秘!
0 目标 生成订单接口的基准场景是什么结果。 SQL的问题定位
533 0