当前位置: 首页 > news >正文

Spring Boot多数据源配置运行报错:No operations allowed after connection closed连接异常的解决

上一篇文章我们讲了如何配置多数据源,但是配置在使用一段时间之后,查询数据库会发生报错:No operations allowed after connection closed。

一、问题原因:
经过排查发现是因为MySQL5.0以后针对超长时间DB连接做了一个处理,那就是如果一个DB连接在无任何操作情况下过了8个小时后(Mysql 服务器默认的“wait_timeout”是8小时),Mysql会自动把这个连接关闭。这就是问题的所在,在连接池中的connections如果空闲超过8小时,mysql将其断开,而连接池自己并不知道该connection已经失效,如果这时有 Client请求connection,连接池将该失效的Connection提供给Client,将会造成上面的异常。
所以配置datasource时需要配置相应的连接池参数,定是去检查连接的有效性,定时清理无效的连接。
二、配置文件修改

#指定连接池最大的空闲连接数量.
spring.datasource.max-idle=10 
#指定连接池等待连接返回的最大等待时间,毫秒单位.
spring.datasource.max-wait=10000 
#指定必须保持连接的最小值(For DBCP and Tomcat connection pools)
spring.datasource.min-idle=5
#指定启动连接池时,初始建立的连接数量
spring.datasource.initial-size=5
#指定获取连接时连接校验的sql查询语句.
spring.datasource.validation-query=SELECT 1
#获取连接时候验证,会影响性能
spring.datasource.test-on-borrow=false
#当连接空闲时,是否执行连接测试.
spring.datasource.test-while-idle=true
#指定空闲连接检查、废弃连接清理、空闲连接池大小调整之间的操作时间间隔
spring.datasource.time-between-eviction-runs-millis=18800 

新增上面的配置之后就不再出现数据库连接超时关闭的问题了。

http://www.lryc.cn/news/149019.html

相关文章:

  • 3、QT 的基础控件的使用
  • 爬虫逆向实战(二十六)--某某学堂登录
  • leetcode分类刷题:哈希表(Hash Table)(四、前缀和 处理连续子数组)
  • 如何处理生产环境中的数据倾斜问题?
  • 【WSN无线传感器网络恶意节点】使用 MATLAB 进行无线传感器网络部署研究
  • C# 实现浏览器控件设置
  • 1130 - Host ‘17216.18083‘ is not allowed to connect to this MySQL server
  • 使用Spring的getBeansOfType实现接口多实现类的动态调用
  • (笔记三)opencv图像基础操作
  • PHP入门及环境搭建 - XAMPP
  • 开学季ipad手写笔什么牌子好?第三方电容笔推荐
  • 【力扣】62. 不同路径 <动态规划>
  • 【Python小项目】Python的GUI库Tkinter实现随机点名工具或抽奖工具并封装成.exe可执行文件
  • 【MySql】mysql之基础语句
  • 使用API调用获取商品数据的完整方案
  • 来看看入门级别的室内设计创意是怎么样构成的
  • Go 面向对象(匿名字段)
  • 生成式AI,赋能数字劳动力的关键工具
  • python提取邮件的附件,以excel为例
  • ZooKeeper技术内幕
  • 乱糟糟的YOLOv8-detect和pose训练自己的数据集
  • 【Nginx】Nginx $remote_addr和$proxy_add_x_forwarded_for变量详解
  • MySQL自动删除binlog日志
  • C++ 文件和流
  • 案例分享:西河水库安全监测信息化系统实施方案
  • 使用Angular和MongoDB来构建具有登录功能的博客应用程序
  • ChatGPT 与前端技术实现制作大屏可视化
  • 视频监控/视频云存储EasyCVR平台接入华为ivs3800平台提示400报错,如何解决?
  • c++基础数据结构
  • 微服务-sentinel详解