druid removeAbandoned 含义 和使用

http://blog.csdn.net/peterwanghao/article/details/40071857 原文地址

removeAbandoned 含义和使用

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


总结:

 含义: 是否开启自动清理被租借的连接但是又没有还回线程池

 作用:

         1.租借的时候放入activeConnections

         2.DyestroyTask定时把没有放回连接池的连接关闭掉

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

[html] view plain copy
  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连接池的超时回收机制,在配置中增加以下内容:

[html] view plain copy
  1.   
  2. <property name="removeAbandoned" value="true" />  
  3.   
  4. <property name="removeAbandonedTimeout" value="180" />  
  5.   
  6. <property name="logAbandoned" value="true" />     

运行程序,当连接超过3分钟后会强制进行回收,并输出堆栈(   转者注:该堆栈是之前使用该连接是new出来的,故可以凭此确认此链接使用没有很好的回收。
 但理论上使用了mybatis,mybatis会负责好连接池申请回放回.

将连接放置到
activeConnections ,然后再DestroyTask里定期把数据关闭掉.
[html] view plain copy
  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)  

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

院里

此配置项会影响性能(转者注:new 线程堆栈),只在排查的时候打开。系统运行时最好关闭。


你可能感兴趣的:(sql)