繁体   English   中英

为什么Spring Boot / Data无法自动配置多个数据源?

[英]Why can't spring boot/data automagically configure multiple data sources?

我有一个连接到两个数据库的spring boot应用程序。 一切正常。

我的包裹结构如下

- db
  - bar
    - BarDbConfig.java
    - domain
      - BarModel.java
    - repo
      - BarRepo.java
  - foo
    - FooDbConfig.java
    - domain
      - FooModel.java
    - repo
      - FooRepo.java

application.properties

spring.jpa.database=default
spring.jpa.database-platform=org.hibernate.dialect.H2Dialect
spring.jpa.hibernate.ddl-auto=none
spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl

#first db
bar.datasource.jdbc-url=jdbc:h2:C:\\Project\\com.example\\db3.data
bar.datasource.username=admin
bar.datasource.password=admin
bar.datasource.driver-class-name=org.h2.Driver

#second db
foo.datasource.jdbc-url=jdbc:h2:C:\\Project\\com.example\\db2.data
foo.datasource.username=admin
foo.datasource.password=admin
foo.datasource.driver-class-name=org.h2.Driver

BarDbConfig.java

@Configuration
@EnableJpaRepositories(
        entityManagerFactoryRef = "barEntityManagerFactory",
        transactionManagerRef = "barTransactionManager"
)
public class BarDbConfig {

    @Bean
    @Primary
    @ConfigurationProperties(prefix = "bar.datasource")
    public DataSource barDataSource() {
        return DataSourceBuilder.create().build();
    }

    @Primary
    @Bean
    public LocalContainerEntityManagerFactoryBean barEntityManagerFactory(
            EntityManagerFactoryBuilder builder,
            @Qualifier("barDataSource") DataSource dataSource
    ) {
        return builder.dataSource(dataSource)
                .packages(BarDbConfig.class.getPackage().getName())
                .persistenceUnit("barPersistenceUnit")
                .build();
    }

    @Primary
    @Bean
    public PlatformTransactionManager barTransactionManager(
            @Qualifier("barEntityManagerFactory") EntityManagerFactory entityManagerFactory) {
        return new JpaTransactionManager(entityManagerFactory);
    }
}

FooDbConfig.java

@Configuration
@EnableJpaRepositories(
        entityManagerFactoryRef = "fooEntityManagerFactory",
        transactionManagerRef = "fooTransactionManager"
)
public class FooDbConfig {

    @Bean
    @ConfigurationProperties(prefix = "foo.datasource")
    public DataSource fooDataSource() {
        return DataSourceBuilder.create().build();
    }

    @Bean
    public LocalContainerEntityManagerFactoryBean fooEntityManagerFactory(
            EntityManagerFactoryBuilder builder,
            @Qualifier("fooDataSource") DataSource dataSource
    ) {
        return builder.dataSource(dataSource)
                .packages(FooDbConfig.class.getPackage().getName())
                .persistenceUnit("fooPersistenceUnit")
                .build();
    }

    @Bean
    public PlatformTransactionManager fooTransactionManager(
            @Qualifier("fooEntityManagerFactory") EntityManagerFactory entityManagerFactory) {
        return new JpaTransactionManager(entityManagerFactory);
    }
}

但是,我想知道所有这些样板代码是否真的必要?

  • 有没有办法删除所有LocalContainerEntityManagerFactoryBeanPlatformTransactionManager东西?
  • 有什么理由需要提供所有这些显式的Qualifier -name?
  • Spring Boot自身无法找到并自动配置数据源吗?
  • 使用约定优于配置连接到两个数据库所需的绝对最低限度的代码是什么?

我将在标题中回答您提出的一个问题,然后在问题正文中再次回答:

Spring Boot自身无法找到并自动配置DataSource吗?

99%的应用程序使用一个数据库,在这些情况下,很明显您想要发生什么,这就是Boot为您所做的。

如果您的应用程序中有2个数据库,那么会有很多问题没有合理的默认答案:

哪些存储库应使用哪个DataSource 按包拆分? 每个接口都有两个存储库? 有路由DataSource 应该以什么标准来处理请求?

您是要跨多个DataSource交易还是要进行单独的交易? 或两者都适用于不同的用例?

当然,Boot可以为所有这些问题选择一个可能的答案,但是结果仅对已经很小的一组开发人员的一小部分有用。 因此,它没有完成。

当然,如果您发现某些事情几乎总是以某种方式完成的,那么我确定Spring Boot开发人员会赞赏功能请求。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM