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,否则会失效

相关推荐
转转技术团队33 分钟前
二奢仓店的静默打印代理实现
java·后端
钢铁男儿1 小时前
C# 接口(什么是接口)
java·数据库·c#
丶小鱼丶1 小时前
排序算法之【归并排序】
java·排序算法
上上迁1 小时前
分布式生成 ID 策略的演进和最佳实践,含springBoot 实现(Java版本)
java·spring boot·分布式
永日456701 小时前
学习日记-spring-day42-7.7
java·学习·spring
秋千码途1 小时前
小架构step系列07:查找日志配置文件
spring boot·后端·架构
龙谷情Sinoam1 小时前
扩展若依@Excel注解,使其对字段的控制是否导出更加便捷
java
__风__2 小时前
PostgreSQL kv(jsonb)存储
数据库·postgresql
二十雨辰2 小时前
[尚庭公寓]07-Knife快速入门
java·开发语言·spring
Databend2 小时前
Databend 产品月报(2025年6月)
数据库