druid removeAbandoned 含义 和使用
2016-03-04 23:07
337 查看
http://blog.csdn.net/peterwanghao/article/details/40071857 原文地址
removeAbandoned 含义和使用原名:使用druid连接池的超时回收机制排查连接泄露问题
总结:含义: 是否开启自动清理被租借的连接但是又没有还回线程池
作用:
1.租借的时候放入activeConnections
2.DyestroyTask定时把没有放回连接池的连接关闭掉
在工程中使用了druid连接池,运行一段时间后系统出现异常:
[html]
view plain
copy
Caused by: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60009, active 50
at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:80)
at org.springframework.jdbc.support.JdbcUtils.extractDatabaseMetaData(JdbcUtils.java:280)
... 64 more
Caused by: com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60000, active 50
at com.alibaba.druid.pool.DruidDataSource.getConnectionInternal(DruidDataSource.java:1071)
at com.alibaba.druid.pool.DruidDataSource.getConnectionDirect(DruidDataSource.java:898)
at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4544)
mysql数据库最大连接数设置为500,使用客户端能正常连接。连接数被未被占满。
分析原因应该是程序中有地方连接未关闭造成的。那如何来定呢?使用druid连接池的超时回收机制,在配置中增加以下内容:
[html]
view plain
copy
<!-- 超过时间限制是否回收 -->
<property name="removeAbandoned" value="true" />
<!-- 超时时间;单位为秒。180秒=3分钟 -->
<property name="removeAbandonedTimeout" value="180" />
<!-- 关闭abanded连接时输出错误日志 -->
<property name="logAbandoned" value="true" />
运行程序,当连接超过3分钟后会强制进行回收,并输出堆栈(
转者注:该堆栈是之前使用该连接是new出来的,故可以凭此确认此链接使用没有很好的回收。
但理论上使用了mybatis,mybatis会负责好连接池申请回放回.
将连接放置到activeConnections ,然后再DestroyTask里定期把数据关闭掉.
[html]
view plain
copy
2014-10-13 16:02:28,919 ERROR [com.alibaba.druid.pool.DruidDataSource] - <abandon connection, open stackTrace
at java.lang.Thread.getStackTrace(Thread.java:1567)
at com.alibaba.druid.pool.DruidDataSource.getConnectionDirect(DruidDataSource.java:995)
at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4544)
at com.alibaba.druid.filter.stat.StatFilter.dataSource_getConnection(StatFilter.java:661)
at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4540)
at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:919)
at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:911)
at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:98)
at cn.org.xxx.xxx.xxx.PaginationInterceptor.intercept(PaginationInterceptor.java:96)
at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:60)
at com.sun.proxy.$Proxy59.query(Unknown Source)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:108)
很清楚地看到是在哪里打开的连接未关闭一直在占有。
院里
此配置项会影响性能(转者注:new 线程堆栈),只在排查的时候打开。系统运行时最好关闭。
相关文章推荐
- setRequestedOrientation 改变屏幕方法
- HDU Common Subsequence
- Codeforces 632D Longest Subsequence 【求因子和变形】
- 关于easy- ui - tree的前篇 (1):
- 1.3:Union-Find算法-----quick-find算法
- OSWatcher Analyzer User Guide (文档 ID 461053.1)
- 矩阵乘法(SequenceFile作为输入源)--使用IDEA调试
- Requests库的几种请求 - 通过API操作Github
- 不能将多个项传入“Microsoft.Build.Framework.ITaskItem”类型的参数
- 深入掌握include_once与require_once的区别
- POJ3581 Sequence(后缀数组)
- 中间透明的UIView实现的几种方法
- iOS UIBezierPath 路径裁剪
- ue4点滴
- Java StringBuilder & StringBuffer 源代码分析
- USACO 之 Section 1.4 More Search Techniques (已解决)
- 华为EMUI4.0 基于android 6.0的bug
- BlockingQueue
- Android源码浅析: Message/Handler/MessageQueue/Looper
- PAT (Advanced Level) Practise 1017 Queueing at Bank (25)