application.properties里的配置如下,注意要使用jdbc-url,否則會出現jdbcUrl is required with driverClassName:
spring.datasource.primary.jdbc-url=jdbc:mysql://xxx1/xxx spring.datasource.primary.username=xxx spring.datasource.primary.password=xxx spring.datasource.secondary.jdbc-url=jdbc:mysql://xxx.xxx.xxx.xxx:xxxx/xxx spring.datasource.secondary.username = xxxx spring.datasource.secondary.password = xxxx
DataSourceConfig,一般就找個config文件夾放着:
import javax.sql.DataSource; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.boot.jdbc.DataSourceBuilder; @Configuration public class DataSourceConfig { @Bean(name = "primaryDataSource") @Qualifier("primaryDataSource") @ConfigurationProperties(prefix="spring.datasource.primary") public DataSource primaryDataSource() { return DataSourceBuilder.create().build(); } @Bean(name = "secondaryDataSource") @Qualifier("secondaryDataSource") @Primary @ConfigurationProperties(prefix="spring.datasource.secondary") public DataSource secondaryDataSource() { return DataSourceBuilder.create().build(); } @Bean(name="primaryJdbcTemplate") public JdbcTemplate primaryJdbcTemplate (@Qualifier("primaryDataSource") DataSource dataSource ) { return new JdbcTemplate(dataSource); } @Bean(name="secondaryJdbcTemplate") public JdbcTemplate secondaryJdbcTemplate(@Qualifier("secondaryDataSource") DataSource dataSource) { return new JdbcTemplate(dataSource); } }
在dao層,也就是實際從數據庫查詢數據的那一層,這樣使用,在Qualifier后寫需要的連接配置:
@Autowired @Qualifier("primaryJdbcTemplate") public JdbcTemplate jdbcTemplate;
特別注意一不小心會報錯 jdbcUrl is required with driverClassName 。