首页 文章

如何使用多个数据源创建Spring Boot项目?

提问于
浏览
4

我正在开发一个Spring Boot / Spring Batch项目,我需要配置两个数据源 . 一个是用于跟踪事务的内存中hsqldb数据库 . 另一个是常规MySQL数据库,将由我的ItemWriters更新 .

问题是,一旦我尝试配置第二个数据源,Spring就会开始抛出“无法解析的循环依赖”错误,即

Error creating bean with name 'preprodDataSource' defined in class path 
resource [xxx/tools/batch/xxx/MyConfiguration.class]: Initialization of
bean failed; nested exception is 
org.springframework.beans.factory.BeanCurrentlyInCreationException: Error 
creating bean with name 'dataSourceAutoConfigurationInitializer': Requested bean is 
currently in creation: Is there an unresolvable circular reference?

我的MyConfiguration.java文件的相关块看起来像:

@Bean
public DataSource transactionsDataSource() {
    BasicDataSource dataSource = new BasicDataSource();
    dataSource.setDriverClassName("org.hsqldb.jdbcDriver");
    dataSource.setUrl("jdbc:hsqldb:mem:testdb;sql.enforce_strict_size=true;hsqldb.tx=mvcc");
    dataSource.setUsername("sa");
    dataSource.setPassword("");
    return dataSource;
}

@Bean
public DataSource preprodDataSource() {
    BasicDataSource dataSource = new BasicDataSource();
    dataSource.setDriverClassName("com.mysql.jdbc.Driver");
    dataSource.setUrl("jdbc:mysql://localhost:3306/somedb");
    dataSource.setUsername("someuser");
    dataSource.setPassword("somepass");
    return dataSource;
}

如果我注释掉定义第二个数据源的@Bean,一切都很好 . 应用程序启动并运行没有问题 . 但是,如果我留下它,我会得到上面的错误 .

我对此的天真解释是Spring正在构建一个'dataSourceAutoConfigurationInitializer'实例来处理第一个数据源的初始化,当它试图构造第二个数据源来处理第二个数据源时,会发生不好的事情 .

有什么方法可以解决这个问题吗?

1 回答

  • 2

    默认情况下,Spring Boot的自动配置将尝试使用您的应用程序 DataSource 为您创建 JdbcTemplate . 正如您配置了两个,它不知道使用哪一个 . 要告诉它应该使用哪一个mark one of them as @Primary

    @Bean
    @Primary
    public DataSource transactionsDataSource() {
        BasicDataSource dataSource = new BasicDataSource();
        …
        return dataSource;
    }
    

    或者,你可以disable the auto-configuration .

相关问题