Aktualizacja 2018-01-07 z Spring Boot 1.5.8. ZWOLNIENIE
Większość odpowiedzi nie podaje, jak ich używać (jako samego źródła danych i jako transakcji), a jedynie jak je skonfigurować.
Możesz zobaczyć wykonalny przykład i wyjaśnienie w https://www.surasint.com/spring-boot-with-multiple-databases-example/
Skopiowałem tutaj trochę kodu.
Najpierw musisz ustawić application.properties w ten sposób
#Database
database1.datasource.url=jdbc:mysql://localhost/testdb
database1.datasource.username=root
database1.datasource.password=root
database1.datasource.driver-class-name=com.mysql.jdbc.Driver
database2.datasource.url=jdbc:mysql://localhost/testdb2
database2.datasource.username=root
database2.datasource.password=root
database2.datasource.driver-class-name=com.mysql.jdbc.Driver
Następnie zdefiniuj ich jako dostawców (@Bean) w następujący sposób:
@Bean(name = "datasource1")
@ConfigurationProperties("database1.datasource")
@Primary
public DataSource dataSource(){
return DataSourceBuilder.create().build();
}
@Bean(name = "datasource2")
@ConfigurationProperties("database2.datasource")
public DataSource dataSource2(){
return DataSourceBuilder.create().build();
}
Zauważ, że mam @Bean (name = "datasource1") i @Bean (name = "datasource2"), wtedy możesz go użyć, gdy potrzebujemy źródła danych jako @Qualifier ("datasource1") i @Qualifier ("datasource2"), na przykład
@Qualifier("datasource1")
@Autowired
private DataSource dataSource;
Jeśli zależy Ci na transakcji, musisz zdefiniować DataSourceTransactionManager dla obu z nich, w następujący sposób:
@Bean(name="tm1")
@Autowired
@Primary
DataSourceTransactionManager tm1(@Qualifier ("datasource1") DataSource datasource) {
DataSourceTransactionManager txm = new DataSourceTransactionManager(datasource);
return txm;
}
@Bean(name="tm2")
@Autowired
DataSourceTransactionManager tm2(@Qualifier ("datasource2") DataSource datasource) {
DataSourceTransactionManager txm = new DataSourceTransactionManager(datasource);
return txm;
}
Następnie możesz go użyć jak
@Transactional //this will use the first datasource because it is @primary
lub
@Transactional("tm2")
To powinno wystarczyć. Zobacz przykład i szczegóły w linku powyżej.