com.alibaba.druid.pool.DruidDataSource : testWhileIdle is true, validationQuery not set
druid
阿里云计算平台DataWorks(https://help.aliyun.com/document_detail/137663.html) 团队出品,为监控而生的数据库连接池
项目地址:https://gitcode.com/gh_mirrors/druid/druid
·
问题释义: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来保证。
阿里云计算平台DataWorks(https://help.aliyun.com/document_detail/137663.html) 团队出品,为监控而生的数据库连接池
最近提交(Master分支:4 个月前 )
933dee04 - 16 天前
3246166f
- Add constructor with SQLParserFeature support to SparkStatementParser
- Fix SQLParserUtils to pass features parameter to SparkStatementParser, CKStatementParser and StarRocksStatementParser 26 天前
AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。
更多推荐


所有评论(0)