spring boot 项目启动报错, error :testWhileIdle is true, validationQuery not set

本文档介绍了在Spring Boot项目中使用阿里Druid数据源时遇到的问题及解决方案。通过添加特定的Druid配置,如`test-while-idle`、`validation-query`等参数,可以消除启动错误。同时,对于多数据源的情况,配置应放在对应的分数据源下,确保每个数据源都有正确的配置。修改配置后,项目成功启动。
摘要由CSDN通过智能技术生成

主要是使用阿里的druid报的错,pom如下:

<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>druid-spring-boot-starter</artifactId>
  <version>1.1.17</version>
</dependency>

只要在yml配置文件中加上以下代码就ok,

druid:
    #指明连接是否被空闲连接回收器(如果有)进行检验.如果检测失败,则连接将被从池中去除.
    test-while-idle: true
    #验证连接是否可用,使用的SQL语句
    validation-query: SELECT 1
    #借出连接时不要测试,否则很影响性能
    test-on-borrow: false
    test-on-return: false

如果是多数据源,请放在分数据源下,如下

spring:
  datasource:
    dynamic:
      primary: ds1
      datasource:
        ds1: #数据源1
          driver-class-name: com.mysql.cj.jdbc.Driver
          url: jdbc:mysql://192.168.1.100:3306/maintenance?characterEncoding=UTF-8&useUnicode=true&useSSL=false&tinyInt1isBit=false&allowPublicKeyRetrieval=true&serverTimezone=Asia/Shanghai&autoReconnect=true&failOverReadOnly=false
          username: root
          password: 123456
        ds2: #数据源2
          type: com.alibaba.druid.pool.DruidDataSource
          driver-class-name: com.dbcp.jdbc.Driver
          url: jdbc:dbcp://192.168.1.101:3333/upbms
          username: root
          password: 123456
          druid:
            #指明连接是否被空闲连接回收器(如果有)进行检验.如果检测失败,则连接将被从池中去除.
            test-while-idle: true
            #验证连接是否可用,使用的SQL语句
            validation-query: SELECT 1
            #借出连接时不要测试,否则很影响性能
            test-on-borrow: false
            test-on-return: false

修改后,启动项目,error消失

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值