java.sql.SQLException: connection closed

2023-09-09 12:16:41.176 [Druid-ConnectionPool-Destroy-181260145] ERROR c.a.d.p.DruidDataSource(3078) - abandon connection, owner thread: http-nio-8005-exec-10, connected at : 1694232698110, open stackTrace

at java.lang.Thread.getStackTrace(Thread.java:1559)

2023-09-09 12:16:41.180 [Druid-ConnectionPool-Destroy-181260145] ERROR c.a.d.p.DruidDataSource(3078) - abandon connection, owner thread: http-nio-8005-exec-1, connected at : 1694232696002, open stackTrace

at java.lang.Thread.getStackTrace(Thread.java:1559)

2023-09-09 12:17:10.105 [http-nio-8005-exec-1] ERROR

2023-09-09 12:17:10.107 [http-nio-8005-exec-1] ERROR

2023-09-09 12:17:11.051 [http-nio-8005-exec-10]

druid配置:

removeAbandoned: true

removeAbandonedTimeout: 300

从被获取到开始计时,如果在removeAbandonedTimeout规定的时间内,还没有关闭的话,就自动进行移除处理。druid的开发者增加这个功能的目的是为了自动移除程序员编程过程中忘记close的connection。而如何断定程序员忘记关闭连接,是通过时间来界定的,removeAbandonedTimeout的默认值是5分钟,我看很多产品都把这个值设置为10分钟,也就是说,如果连接从被获取到被关闭超过10分钟,就会被自动移除。

连接因长SQL一直没有执行完,占用超过removeAbandonedTimeout时被移除,然而在移除时报错了,但因移除报错,此连接还是存在连接池,而实际连接又关闭了,后续再继续拿到的时候就报sqlException:connection closed;

参考:

https://www.modb.pro/db/171346

Druid连接池 报错:abandon connection原因分析_wtopps的博客-CSDN博客

方案一:removeAbandoned设置为false或removeAbandonedTimeout调大;

方案二:在数据库的url链接中加&queryTimeout=75

相关推荐
json{shen:"jing"}3 分钟前
分割回文串-暴力法
java·算法
github.com/starRTC6 分钟前
Claude Code中英文系列教程34:再谈Skills
开发语言·c#·ai编程
没有bug.的程序员7 分钟前
Maven 进阶进阶:依赖优化内核、多模块构建艺术与“依赖地狱”自愈指南
java·maven·构建·多模块·依赖优化
毕设源码-赖学姐10 分钟前
【开题答辩全过程】以 基于Java的外卖点餐网站为例,包含答辩的问题和答案
java·开发语言
追随者永远是胜利者14 分钟前
(LeetCode-Hot100)4. 寻找两个正序数组的中位数
java·算法·leetcode·职场和发展·go
追随者永远是胜利者16 分钟前
(LeetCode-Hot100)2. 两数相加
java·算法·leetcode·go
蜡笔羊驼29 分钟前
LALIC环境安装过程
开发语言·python·深度学习
codeJinger34 分钟前
【Python】基础知识
开发语言·python
前路不黑暗@35 分钟前
Java项目:Java脚手架项目通用基类和常量类的封装(九)
java·spring boot·笔记·学习·spring cloud·maven·intellij-idea
lsx2024061 小时前
JavaScript Math(算数)详解
开发语言