[已解决] java.sql.SQLException: connection holder is null

得意时要看淡,失意时要看开。不论得意失意,切莫大意;不论成功失败,切莫止步。志得意满时,需要的是淡然,给自己留一条退路;失意落魄时,需要的是泰然,给自己觅一条出路[已解决] java.sql.SQLException: connection holder is null,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

文章目录

问题

SpringBoot项目中使用Druid连接池,遇到下面的错误:
Cause: java.sql.SQLException: connection holder is null
; uncategorized SQLException; SQL state [null]; error code [0]; connection holder is null; nested exception is java.sql.SQLException: connection holder is null

异常的出现是属于获取连接超时,从而找不到持有者。
上面的错误信息,是来自于Druid源码,大家有兴趣可以看一下。

网上解决方法比较多的都是修改配置文件,设置abandoned超时时间,我的项目中的配置如下,看起来是没有问题的:

spring:
  datasource:
  	...
    removeAbandoned: true # 是否自动回收超时连接
    removeAbandonedTimeout: 1800 # 超时时间(以秒数为单位)

分析和解决

分析下来,原因应该是程序中有地方连接未关闭造成的。
那如何来定呢?使用druid连接池的超时回收机制,在配置中增加以下内容:

spring:
  datasource:
  	...
    removeAbandoned: true # 是否自动回收超时连接
    removeAbandonedTimeout: 1800 # 超时时间(以秒数为单位)
    logAbandoned: true # 关闭abandoned连接时输出错误日志

运行程序,当Druid强制进行回收时,会输出异常日志。
很清楚地看到是在哪里打开的连接未关闭一直在占有。
此配置项会影响性能,只在排查的时候打开。
系统运行时最好关闭。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/155677.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!