问题释义:testWhileIdle 是 true, validationQuery 没有设置

去看看testWhileIdle属性的默认值,果然如提示所说为true:

再看看validationQuery属性的默认值,也如提示所说为null,即没有设置:

解决:当我们的testWhileIdle属性为默认的true时,必须设置校验的sql(validationQuery )。所以只要将testWhileIdle属性设置为false或者指定好校验的sql(validationQuery )即可。

properties形式的相关配置 

#申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
spring.datasource.druid.test-on-borrow=false
#建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。
spring.datasource.druid.test-while-idle=true
#归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
spring.datasource.druid.test-on-return=false
#用来检测连接是否有效的sql,要求是一个查询语句,常用select 'x'
spring.datasource.druid.validation-query=SELECT 1

yml形式的相关配置

datasource:
  type: com.alibaba.druid.pool.DruidDataSource            # 当前数据源操作类型
  driver-class-name: org.gjt.mm.mysql.Driver              # mysql驱动包
  url: jdbc:mysql://localhost:3306/db2019?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=false
  username: root
  password: root
  druid:
    validation-query: select 1
    test-on-borrow: false

说明:testOnBorrow=false表示不检测池中连接的可用性,生产环境一般不开启,影响性能。失效连接主要通过testWhileIdle来保证。

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐