java holder_java.sql.SQLException: connection holder is null
錯誤信息
2017-11-15 14:53:16.931 [ ] ERROR com.hzcf.flagship.web.AssetPlanController 126 :
### Error updating database. Cause: java.sql.SQLException: connection holder is null
### Cause: java.sql.SQLException: connection holder is null
; uncategorized SQLException for SQL []; SQL state [null]; error code [0]; connection holder is null; nested exception is java.sql.SQLException: connection holder is null
原因
一般都是因為程序從線程池中獲取數據庫連接后,長時間占用未及時close導致。
druid鏈接池有removeAbandoned功能,意思是一個數據庫連接池被get后,需要在一定的時間(即removeAbandonedTimeout秒)歸還給連接池,否則,就會被druid關掉:
JdbcUtils.close(pooledConnection);
removeAbandonedTimeout配置:
通過datasource.getConnontion() 取得的連接必須在removeAbandonedTimeout這么多秒內調用close(),要不就會被連接池自動關閉鏈接。(就是conn不能超過指定的租期)
結合removeAbandonedTimeout進行錯誤分析
在工程中使用了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分鐘(即:removeAbandonedTimeout秒)后會強制進行回收,并輸出異常日志。
2014-10-13 16:02:28,919 ERROR [com.alibaba.druid.pool.DruidDataSource] -
at java.lang.Thread.getStackTrace(Thread.java:1567)
at com.alibaba.druid.pool.DruidDataSource.getConnectionDirect(DruidDataSource.java:995)
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)
很清楚地看到是在哪里打開的連接未關閉一直在占有,然后再結合源碼,把根本問題找到并改正。
總結
連接池為了防止程序從池里取得連接后忘記歸還的情況, 而提供了一些參數來設置一個租期, 使用這個可以在一定程度上防止連接泄漏
但是如果你的業務真要跑這么久~~~~那還是注意下這個設置.
此配置項會影響性能,最好只在排查的時候打開。系統運行時最好關閉。
參考
總結
以上是生活随笔為你收集整理的java holder_java.sql.SQLException: connection holder is null的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql 强制使用索引_快速找出MyS
- 下一篇: java二维数组 内存分配_java中二