Spring Boot Configure and Use Two DataSources

后端 未结 9 2162
不思量自难忘°
不思量自难忘° 2020-11-22 04:26

How can I configure and use two data sources?

For example here is what I have for the first data source:

application.properties



        
9条回答
  •  无人共我
    2020-11-22 05:17

    My requirement was slightly different but used two data sources.

    I have used two data sources for same JPA entities from same package. One for executing DDL at the server startup to create/update tables and another one is for DML at runtime.

    The DDL connection should be closed after DDL statements are executed, to prevent further usage of super user previlleges anywhere in the code.

    Properties

    spring.datasource.url=jdbc:postgresql://Host:port
    ddl.user=ddluser
    ddl.password=ddlpassword
    dml.user=dmluser
    dml.password=dmlpassword
    spring.datasource.driver-class-name=org.postgresql.Driver
    

    Data source config classes

    //1st Config class for DDL Data source

      public class DatabaseDDLConfig {
            @Bean
            public LocalContainerEntityManagerFactoryBean ddlEntityManagerFactoryBean() {
                LocalContainerEntityManagerFactoryBean entityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();
                PersistenceProvider persistenceProvider = new 
                org.hibernate.jpa.HibernatePersistenceProvider();
                entityManagerFactoryBean.setDataSource(ddlDataSource());
                entityManagerFactoryBean.setPackagesToScan(new String[] { 
                "com.test.two.data.sources"});
                HibernateJpaVendorAdapter vendorAdapter = new 
                HibernateJpaVendorAdapter();
                entityManagerFactoryBean.setJpaVendorAdapter(vendorAdapter);
                HashMap properties = new HashMap<>();
                properties.put("hibernate.dialect", 
                "org.hibernate.dialect.PostgreSQLDialect");
                properties.put("hibernate.physical_naming_strategy", 
                "org.springframework.boot.orm.jpa.hibernate.
                SpringPhysicalNamingStrategy");
                properties.put("hibernate.implicit_naming_strategy", 
                "org.springframework.boot.orm.jpa.hibernate.
                SpringImplicitNamingStrategy");
                properties.put("hibernate.hbm2ddl.auto", "update");
                entityManagerFactoryBean.setJpaPropertyMap(properties);
                entityManagerFactoryBean.setPersistenceUnitName("ddl.config");
                entityManagerFactoryBean.setPersistenceProvider(persistenceProvider);
                return entityManagerFactoryBean;
            }
    
    
        @Bean
        public DataSource ddlDataSource() {
            DriverManagerDataSource dataSource = new DriverManagerDataSource();
            dataSource.setDriverClassName(env.getProperty("spring.datasource.driver-class-name"));
            dataSource.setUrl(env.getProperty("spring.datasource.url"));
            dataSource.setUsername(env.getProperty("ddl.user");
            dataSource.setPassword(env.getProperty("ddl.password"));
            return dataSource;
        }
    
        @Bean
        public PlatformTransactionManager ddlTransactionManager() {
            JpaTransactionManager transactionManager = new JpaTransactionManager();
            transactionManager.setEntityManagerFactory(ddlEntityManagerFactoryBean().getObject());
            return transactionManager;
        }
    }
    

    //2nd Config class for DML Data source

    public class DatabaseDMLConfig {
    
        @Bean
        @Primary
        public LocalContainerEntityManagerFactoryBean dmlEntityManagerFactoryBean() {
            LocalContainerEntityManagerFactoryBean entityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();
            PersistenceProvider persistenceProvider = new org.hibernate.jpa.HibernatePersistenceProvider();
            entityManagerFactoryBean.setDataSource(dmlDataSource());
            entityManagerFactoryBean.setPackagesToScan(new String[] { "com.test.two.data.sources" });
            JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
            entityManagerFactoryBean.setJpaVendorAdapter(vendorAdapter);
            entityManagerFactoryBean.setJpaProperties(defineJpaProperties());
            entityManagerFactoryBean.setPersistenceUnitName("dml.config");
            entityManagerFactoryBean.setPersistenceProvider(persistenceProvider);
            return entityManagerFactoryBean;
        }
    
        @Bean
        @Primary
        public DataSource dmlDataSource() {
            DriverManagerDataSource dataSource = new DriverManagerDataSource();
            dataSource.setDriverClassName(env.getProperty("spring.datasource.driver-class-name"));
            dataSource.setUrl(envt.getProperty("spring.datasource.url"));
            dataSource.setUsername("dml.user");
            dataSource.setPassword("dml.password");
            return dataSource;
        }
    
        @Bean
        @Primary
        public PlatformTransactionManager dmlTransactionManager() {
            JpaTransactionManager transactionManager = new JpaTransactionManager();
            transactionManager.setEntityManagerFactory(dmlEntityManagerFactoryBean().getObject());
            return transactionManager;
        }
    
    
      }
    

    //Usage of DDL data sources in code.

    public class DDLServiceAtStartup {
    
    //Import persistence unit ddl.config for ddl purpose.
    
    @PersistenceUnit(unitName = "ddl.config")
    private EntityManagerFactory entityManagerFactory;
    
    public void executeDDLQueries() throws ContentServiceSystemError {
        try {
            EntityManager entityManager = entityManagerFactory.createEntityManager();
            entityManager.getTransaction().begin();
            entityManager.createNativeQuery("query to create/update table").executeUpdate();
            entityManager.flush();
            entityManager.getTransaction().commit();
            entityManager.close();
    
            //Close the ddl data source to avoid from further use in code.
            entityManagerFactory.close();
        } catch(Exception ex) {}
    }
    

    //Usage of DML data source in code.

    public class DDLServiceAtStartup {
      @PersistenceUnit(unitName = "dml.config")
      private EntityManagerFactory entityManagerFactory;
    
      public void createRecord(User user) {
         userDao.save(user);
      }
    }
    

提交回复
热议问题