【问题标题】:Adding a second datasource - SpringBoot RepositoryRestService PersistenceConfig添加第二个数据源 - SpringBoot RepositoryRestService PersistenceConfig
【发布时间】:2014-12-29 11:06:52
【问题描述】:

我正在尝试寻找向我们的应用程序添加第二个数据源的最佳方法。主要目的是通过休息公开针对数据库的 CRUD 操作,并且需要针对第二个数据库反弹以进行身份​​验证和角色管理。我们没有使用 XML 配置。

有没有办法在现有的 PersistenceConfig.java 文件中简单地添加第二个数据源 bean,或者我们需要为第二个数据库实例复制整个配置类?

应用程序:

包 foo;

import foo.config.PersistenceConfig;
import foo.config.RepositoryRestConfig;
import foo.config.WebConfig;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;

@Configuration
@ComponentScan
@EnableJpaRepositories
@Import({PersistenceConfig.class, WebConfig.class, RepositoryRestConfig.class})
@EnableAutoConfiguration
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

}

回购:

package foo.repository;

import foo.Widget;
import org.springframework.data.repository.CrudRepository;
import org.springframework.data.repository.query.Param;
import org.springframework.data.rest.core.annotation.RepositoryRestResource;

import java.util.List;

@RepositoryRestResource(collectionResourceRel = "widgets", path = "widgets")
public interface WidgetsRepository extends CrudRepository<Widget, Long> {
    List<Widget> findByWidgetId(@Param("widgetid") long widgetId);
}   

持久化配置:

package foo.config;

import org.apache.commons.dbcp2.BasicDataSource;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.context.annotation.Primary;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.data.rest.webmvc.config.RepositoryRestMvcConfiguration;
import org.springframework.orm.jpa.JpaDialect;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.orm.jpa.vendor.Database;
import org.springframework.orm.jpa.vendor.HibernateJpaDialect;
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;

import javax.persistence.PersistenceContext;
import javax.sql.DataSource;


@Configuration
@Import(RepositoryRestMvcConfiguration.class)
@EnableJpaRepositories
@EnableTransactionManagement

public class PersistenceConfig {

    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
        final HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
        vendorAdapter.setDatabase(Database.SQL_SERVER);
        vendorAdapter.setShowSql(true);

        final LocalContainerEntityManagerFactoryBean factory = new LocalContainerEntityManagerFactoryBean();
        factory.setJpaVendorAdapter(vendorAdapter);
        factory.setPackagesToScan("foo.model");
        factory.setDataSource(dataSource());
        return factory;
    }

    @Bean(destroyMethod = "close")
    public DataSource dataSource() {
        BasicDataSource dataSource = new BasicDataSource();
        dataSource.setDriverClassName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
        dataSource.setUrl("jdbc:sqlserver://127.0.0.1:1433;databaseName=fooDB");
        dataSource.setUsername("sa");
        dataSource.setPassword("*******");
        dataSource.setTestOnBorrow(true);
        dataSource.setTestOnReturn(true);
        dataSource.setTestWhileIdle(true);
        dataSource.setTimeBetweenEvictionRunsMillis(1800000L);
        dataSource.setNumTestsPerEvictionRun(3);
        dataSource.setMinEvictableIdleTimeMillis(1800000L);
        dataSource.setValidationQuery("SELECT 1");
        return dataSource;
    }


    @Bean
    public JpaDialect jpaDialect() {
        return new HibernateJpaDialect();
    }

    @Bean
    public PlatformTransactionManager transactionManager() {
        JpaTransactionManager txManager = new JpaTransactionManager();
        txManager.setEntityManagerFactory(entityManagerFactory().getObject());
        return txManager;
    }

}

感谢您的帮助...

【问题讨论】:

    标签: java spring-boot spring-data-jpa


    【解决方案1】:

    看看@Qualifier注解。使用此注释,您可以定义相同类型的各种 bean 并为其分配名称。相当于bean XML 标记中的id 参数。

    这是relevant part of Spring documentation

    【讨论】:

      【解决方案2】:

      首先值得注意的是,PersistenceConfig 中的几乎所有配置都是多余的,因为 Spring Boot 会自动为您配置。几乎唯一非默认且您需要指定的是您的 DataSource 配置,例如 SQLServer URL。

      有一个section in the documentation 描述了如何使用@Primaryapplication.properties 配置两个DataSource:

      创建多个数据源的工作方式与创建第一个数据源相同。如果您使用 JDBC 或 JPA 的默认自动配置,您可能希望将其中一个标记为 @Primary(然后任何 @Autowired 注入都会选择该配置)。"

      @Bean
      @Primary
      @ConfigurationProperties(prefix="datasource.primary")
      public DataSource primaryDataSource() {
          return DataSourceBuilder.create().build();
      }
      
      @Bean
      @ConfigurationProperties(prefix="datasource.secondary")
      public DataSource secondaryDataSource() {
          return DataSourceBuilder.create().build();
      }
      

      然后,您将使用 application.properties 以及 datasource.primarydatasource.secondary 前缀配置这两个数据源:

      例如:

      datasource.primary.jdbcUrl=jdbc:sqlserver://127.0.0.1:1433;databaseName=fooDB
      datasource.primary.user=sa
      datasource.primary.password=secret
      
      datasource.primary.jdbcUrl=jdbc:sqlserver://127.0.0.1:1433;databaseName=barDB
      datasource.primary.user=sa
      datasource.primary.password=secret
      

      【讨论】:

      • 但是您没有解释如何将辅助资源用于具体存储库 CrudRepository。有了这个,你就有了两个数据源,但你总是使用 Primary。
      猜你喜欢
      • 2013-10-23
      • 2019-10-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-06-10
      • 1970-01-01
      相关资源
      最近更新 更多