Druid连接池最小连接数设置失效问题

问题发现:

配置

当项目启动后

线程池确实是初始化了5条连接,但是当项目运行一段时间后,5条连接确消失了,只会程序用到得时候,再去初始化连接,这样有点违背了参数设置得意义,后来通过查阅资料发现

minEvictableIdleTimeMillis: 最小空闲时间,默认30分钟,如果连接池中非运行中的连接数大于minIdle,并且那部分连接的非运行时间大于minEvictableIdleTimeMillis,则连接池会将那部分连接设置成Idle状态并关闭;也就是说如果一条连接30分钟都没有使用到,并且这种连接的数量超过了minIdle,则这些连接就会被关闭了。
**maxEvictableIdleTimeMillis:**最大空闲时间,默认7小时,如果minIdle设置得比较大,连接池中的空闲连接数一直没有超过minIdle,这时那些空闲连接是不是一直不用关闭?当然不是,如果连接太久没用,数据库也会把它关闭,这时如果连接池不把这条连接关闭,系统就会拿到一条已经被数据库关闭的连接。为了避免这种情况,Druid会判断池中的连接如果非运行时间大于maxEvictableIdleTimeMillis,也会强行把它关闭,而不用判断空闲连接数是否小于minIdle;

总结

  • minEvictableIdleTimeMillis连接空闲时间大于该值并且池中空闲连接大于minIdle则关闭该连接
  • maxEvictableIdleTimeMillis连接空闲时间大于该值,不管minIdle都关闭该连接

问题解决:

借助keepAlive参数,默认情况下,此参数为false。开启keepAlive,每隔一段时间进行心跳检查,这样就可以初始化空闲时间了。

但是keepAlive是有心跳间隔时间得,默认为60s,可以对系统参数设置keepAliveBetweenTimeMillis值,指定心跳间隔时间。

注意:keepAliveBetweenTimeMillis设置值不能少于minEvictableIdleTimeMillis、maxEvictableIdleTimeMillis,否则会失效

相关推荐
程序员小假9 分钟前
你会不会使用 SpringBoot 整合 Flowable 快速实现工作流呢?
java·后端
来自外太空的鱼-张小张10 分钟前
java将pdf文件转换为图片工具类
java·python·pdf
代码中の快捷键17 分钟前
如何实现一个登录功能?
java·开发语言
陪我一起学编程39 分钟前
关于ORM增删改查的总结——跨表
数据库·后端·python·django·restful
保持学习ing41 分钟前
微服务--消息队列mq
java·微服务·消息队列·rabbitmq·消息转换器
Q_Q51100828542 分钟前
python+django/flask成都奥科厨具厂产品在线销售系统
vue.js·spring boot·python·django·flask·node.js·php
zimoyin1 小时前
Java/Kotlin selenium 无头浏览器 [Headless Chrome] 实现长截图 三种方式
java·selenium·kotlin
yuluo_YX1 小时前
Spring AI Alibaba Graph 实践
java·人工智能·spring
conkl1 小时前
Apache网页优化实战指南 - 让网站加载速度提升
linux·运维·服务器·开发语言·阿里云·apache
天空之城夢主1 小时前
PostgreSQL 初体验
数据库·postgresql