日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

java holder_java.sql.SQLException: connection holder is null

發(fā)布時(shí)間:2024/7/23 数据库 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java holder_java.sql.SQLException: connection holder is null 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

錯(cuò)誤信息

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

原因

一般都是因?yàn)槌绦驈木€程池中獲取數(shù)據(jù)庫(kù)連接后,長(zhǎng)時(shí)間占用未及時(shí)close導(dǎo)致。

druid鏈接池有removeAbandoned功能,意思是一個(gè)數(shù)據(jù)庫(kù)連接池被get后,需要在一定的時(shí)間(即removeAbandonedTimeout秒)歸還給連接池,否則,就會(huì)被druid關(guān)掉:

JdbcUtils.close(pooledConnection);

removeAbandonedTimeout配置:

通過(guò)datasource.getConnontion() 取得的連接必須在removeAbandonedTimeout這么多秒內(nèi)調(diào)用close(),要不就會(huì)被連接池自動(dòng)關(guān)閉鏈接。(就是conn不能超過(guò)指定的租期)

結(jié)合removeAbandonedTimeout進(jìn)行錯(cuò)誤分析

在工程中使用了druid連接池,運(yùn)行一段時(shí)間后系統(tǒng)出現(xiàn)異常:

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數(shù)據(jù)庫(kù)最大連接數(shù)設(shè)置為500,使用客戶端能正常連接。連接數(shù)被未被占滿。

分析原因應(yīng)該是程序中有地方連接未關(guān)閉造成的。那如何來(lái)定呢?使用druid連接池的超時(shí)回收機(jī)制,在配置中增加以下內(nèi)容:

運(yùn)行程序,當(dāng)連接超過(guò)3分鐘(即:removeAbandonedTimeout秒)后會(huì)強(qiáng)制進(jìn)行回收,并輸出異常日志。

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)

很清楚地看到是在哪里打開(kāi)的連接未關(guān)閉一直在占有,然后再結(jié)合源碼,把根本問(wèn)題找到并改正。

總結(jié)

連接池為了防止程序從池里取得連接后忘記歸還的情況, 而提供了一些參數(shù)來(lái)設(shè)置一個(gè)租期, 使用這個(gè)可以在一定程度上防止連接泄漏

但是如果你的業(yè)務(wù)真要跑這么久~~~~那還是注意下這個(gè)設(shè)置.

此配置項(xiàng)會(huì)影響性能,最好只在排查的時(shí)候打開(kāi)。系統(tǒng)運(yùn)行時(shí)最好關(guān)閉。

參考

總結(jié)

以上是生活随笔為你收集整理的java holder_java.sql.SQLException: connection holder is null的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。