在工程中使用了druid連接池,運行一段時間后系統出現異常:
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連接池的超時回收機制,在配置中增加以下內容:
運行程序,當連接超過3分鍾后會強制進行回收,並輸出異常日志。
很清楚地看到是在哪里打開的連接未關閉一直在占有。
此配置項會影響性能,只在排查的時候打開。系統運行時最好關閉。