首页 > 解决方案 > Spring Boot 只初始化一个数据源,而不初始化另一个

问题描述

我关注了多篇关于创建多个数据源的文章,并在我的代码中尝试了相同的方法。但奇怪的是,spring boot 只初始化一个数据源而不是另一个。当我从代码中删除其中任何一个时,另一个创建时没有任何问题。任何想法。

Bean 配置 -

@Configuration
public class DBConfiguration {

    @Bean("dataSource")
    @ConfigurationProperties(prefix = "p.datasource")
    public DataSource pDataSource() {
        System.out.println("**************************> dataSource");
        return DataSourceBuilder.create().build();
    }

    @Bean("storeFrontDataSource")
    @ConfigurationProperties(prefix = "c.datasource")
    public DataSource cDataSource() {
        System.out.println("**************************> storeFrontDataSource");
        return DataSourceBuilder.create().build();
    }
}

YML 文件(出于保密考虑删除了一些数据) -

p:
  datasource:
    url: {some-url}
    driver-class-name: com.ibm.db2.jcc.DB2Driver
    username: abc
    password: xyz
    type: com.zaxxer.hikari.HikariDataSource
    hikari:
      schema:        
      connection-init-sql: select 1 from dual
      minimum-idle: 25
      maximum-pool-size: 100 
      idle-timeout: 10_000
      max-lifetime: 20_000
      connection-timeout: 1_000
      validation-timeout: 500

c:
  datasource:
    url: {some-url}
    driver-class-name: com.ibm.db2.jcc.DB2Driver
    username: abc
    password: xyz
    type: com.zaxxer.hikari.HikariDataSource
    hikari:
      schema:        
      pool-name: uspo-cis-sf-pool
      connection-init-sql: select 1 from dual
      minimum-idle: 1
      maximum-pool-size: 5 
      idle-timeout: 10_000
      max-lifetime: 50_000
      connection-timeout: 2_000 
      validation-timeout: 500

抛出错误 -

仅找到“数据源”bean 而不是“storeFrontDataSource”bean。即使在控制台上,也只有一个 System.out.println() 被调用(即“数据源”),而另一个则不被打印。SpringBoot 甚至没有初始化其他 bean 定义。

Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.zaxxer.hikari.HikariDataSource' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Qualifier(value=storeFrontDataSource)}
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.raiseNoMatchingBeanFound(DefaultListableBeanFactory.java:1790) ~[spring-beans-5.3.3.jar:5.3.3]
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1346) ~[spring-beans-5.3.3.jar:5.3.3]
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:1300) ~[spring-beans-5.3.3.jar:5.3.3]
    at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:887) ~[spring-beans-5.3.3.jar:5.3.3]
    at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:791) ~[spring-beans-5.3.3.jar:5.3.3]
    ... 38 common frames omitted

注意 - 即使定义 @Primary 也无济于事。无论如何, System.out.println() 都应该打印到控制台。

标签: javaspring-bootdatasourcemultiple-databases

解决方案


根据@tgdavies 的建议,我发现依赖库中的一些类正在注入“HikariDataSource”而不是“DataSource”。修复它们后,问题得到解决。


推荐阅读