使用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)  

 


很清楚地看到是在哪里打開的連接未關閉一直在占有。

 

 

此配置項會影響性能,只在排查的時候打開。系統運行時最好關閉。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM