1.application.yml中添加兩個datasourcejava
server: port: 8080 spring: application: name: king datasource: master: type: com.zaxxer.hikari.HikariDataSource jdbc-url: jdbc:mysql://localhost:3306/king?useUnicode=yes&characterEncoding=UTF-8&serverTimezone=UTC driver-class-name: com.mysql.cj.jdbc.Driver username: root password: 123456 idle-timeout: 10000 minimum-idle: 1 maximum-pool-size: 10 pool-name: master auto-commit: false connection-test-query: SELECT 1 slave: type: com.zaxxer.hikari.HikariDataSource jdbc-url: jdbc:mysql://localhost:3306/king?useUnicode=yes&characterEncoding=UTF-8&serverTimezone=UTC driver-class-name: com.mysql.cj.jdbc.Driver username: root password: 123456 idle-timeout: 10000 minimum-idle: 1 maximum-pool-size: 10 pool-name: slave auto-commit: false connection-test-query: SELECT 1
2.手動初始化數據源masterDataSource
package cn.bj.king.config; import com.zaxxer.hikari.HikariConfig; import com.zaxxer.hikari.HikariDataSource; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.spring.annotation.MapperScan; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.boot.jdbc.DataSourceBuilder; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import org.springframework.jdbc.datasource.DataSourceTransactionManager; import org.springframework.transaction.annotation.EnableTransactionManagement; import javax.sql.DataSource; /** * @author ARongking * @date 2019-03-28 */ @Configuration @EnableTransactionManagement @MapperScan(basePackages = {"cn.bj.king.mapper.master"}, sqlSessionFactoryRef = "masterSqlSessionFactory") public class WriteDataSourceConfig { @Bean(name = "masterDataSource") @Primary @Qualifier("masterDataSource") public DataSource masterDataSource(@Qualifier("masterHikariConfig")HikariConfig hikariConfig) { System.out.println("實例化主庫"); HikariDataSource hikariDataSource=new HikariDataSource(hikariConfig); return hikariDataSource; } /** * 配置鏈接池信息 * @return */ @ConfigurationProperties(prefix = "spring.datasource.master") @Bean("masterHikariConfig") public HikariConfig masterHikariConfig(){ HikariConfig hikariConfig=new HikariConfig(); return hikariConfig; } /** * SqlSessionFactory配置 * * @return * @throws Exception */ @Bean(name = "masterSqlSessionFactory") @Primary public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource dataSource) throws Exception { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); sqlSessionFactoryBean.setDataSource(dataSource); PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); // 配置mapper文件位置 sqlSessionFactoryBean.setMapperLocations(resolver.getResources("classpath:mapper/master/*.xml")); sqlSessionFactoryBean.setTypeAliasesPackage("cn.bj.king.entity"); return sqlSessionFactoryBean.getObject(); } /** * 配置事物管理器 * * @return */ @Bean(name = "masterTransactionManager") @Primary public DataSourceTransactionManager masterTransactionManager(@Qualifier("masterDataSource") DataSource dataSource) { DataSourceTransactionManager dataSourceTransactionManager = new DataSourceTransactionManager(); dataSourceTransactionManager.setDataSource(dataSource); return dataSourceTransactionManager; } }
3.手動初始化數據源ReadDataSource
package cn.bj.king.config; import com.github.pagehelper.PageInterceptor; import com.zaxxer.hikari.HikariConfig; import com.zaxxer.hikari.HikariDataSource; import org.apache.ibatis.plugin.Interceptor; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.spring.annotation.MapperScan; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.boot.jdbc.DataSourceBuilder; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.core.env.Environment; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import org.springframework.jdbc.datasource.DataSourceTransactionManager; import org.springframework.transaction.annotation.EnableTransactionManagement; import javax.sql.DataSource; import java.util.Properties; @Configuration @EnableTransactionManagement @MapperScan(basePackages = {"cn.bj.king.mapper.slave"}, sqlSessionFactoryRef = "slaveSqlSessionFactory") public class ReadDataSourceConfig { @Autowired Environment environment; @Bean(name = "slaveDataSource") @Qualifier("slaveDataSource") public DataSource slaveDataSource(@Qualifier("slaveHikariConfig")HikariConfig hikariConfig) { System.out.println("實例化從庫"); HikariDataSource hikariDataSource=new HikariDataSource(hikariConfig); return hikariDataSource; } /** * 配置鏈接池信息 * @return */ @ConfigurationProperties(prefix = "spring.datasource.slave") @Bean("slaveHikariConfig") public HikariConfig slaveHikariConfig(){ HikariConfig hikariConfig=new HikariConfig(); return hikariConfig; } /** * SqlSessionFactory配置 * * @return * @throws Exception */ @Bean(name = "slaveSqlSessionFactory") public SqlSessionFactory slaveSqlSessionFactory(@Qualifier("slaveDataSource") DataSource dataSource) throws Exception { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); sqlSessionFactoryBean.setDataSource(dataSource); PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); // 配置mapper文件位置 sqlSessionFactoryBean.setMapperLocations(resolver.getResources("classpath:mapper/slave/*.xml")); sqlSessionFactoryBean.setTypeAliasesPackage("cn.bj.king.entity"); return sqlSessionFactoryBean.getObject(); } /** * 配置事物管理器 * * @return */ @Bean(name = "slaveTransactionManager") public DataSourceTransactionManager slaveTransactionManager(@Qualifier("slaveDataSource") DataSource dataSource) { DataSourceTransactionManager dataSourceTransactionManager = new DataSourceTransactionManager(); dataSourceTransactionManager.setDataSource(dataSource); return dataSourceTransactionManager; } }
4.測試啓動是否正常初始化master和slave 兩個數據源 5.這裏須要注意幾個地方: * 配置數據庫鏈接池的時候,若是不是手動設置HikariConfig ,即經過Environment 去一個個獲取數據庫鏈接池在yml中的配置的話,數據庫鏈接池的(idle-timeout,minimum-idle, maximum-pool-size,pool-name,auto-commit,connection-test-query)等,必定要與slave節點平級,否則 HikariConfig 是讀取不到這些信息的。 * 若是手動賦值HikariConfig 的話,那就沒有什麼限制了,寫到哪裏都行,只須要用Environment 去讀取配置文件的值,手動設置到HikariConfig 就好了。