隨着應用用戶數量的增長,相應的併發請求的數量也會跟着不斷增長,慢慢地,單個數據庫已經沒有辦法知足咱們頻繁的數據庫操做請求了,在某些場景下,咱們可能會須要配置多個數據源,使用多個數據源(例如實現數據庫的讀寫分離)來緩解系統的壓力等,一樣的,Springboot官方提供了相應的實現來幫助開發者們配置多數據源,通常分爲兩種方式(目前我所瞭解到的),分包和AOP,其中利用AOP實現多個數據源到的動態切換時候會另開一篇文章來寫。考慮到mybatis是java開發者們使用較爲頻繁的數據庫框架,因此本篇文章使用Springboot+Mybatis來實現多數據源的配置。java
廢話很少說,走起。mysql
既然是配置多數據源,那麼咱們天然就要先把相應的數據源給準備好,這裏呢,我本地新建了兩個數據庫,以下表:git
數據庫 | testdatasource1 | testdatasource2 |
---|---|---|
數據表 | sys_user | sys_user2 |
字段 | user_id(int), user_name(varchar) user_age(int) | 同 |
並分別插入兩條記錄,爲了方便對比,其中testdatasource1爲芳年25歲的張三, testdatasource2爲芳年30歲的李四。github
首先新建一個Springboot項目,我這裏版本是2.1.7.RELEASE,並在pom文件中引入相關依賴:關鍵依賴以下:spring
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
複製代碼
到這裏咱們的環境已經基本配置完成了。sql
首先呢,在咱們Springboot的配置文件中配置咱們的datasourse,和以往不同的是,由於咱們有兩個數據源,因此要指定相關數據庫的名稱,其中主數據源爲primary,次數據源爲secondary以下:數據庫
#配置主數據庫
spring.datasource.primary.jdbc-url=jdbc:mysql://localhost:3306/testdatasource1?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC&useSSL=false
spring.datasource.primary.username=root
spring.datasource.primary.password=root
spring.datasource.primary.driver-class-name=com.mysql.cj.jdbc.Driver
##配置次數據庫
spring.datasource.secondary.jdbc-url=jdbc:mysql://localhost:3306/testdatasource2?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC&useSSL=false
spring.datasource.secondary.username=root
spring.datasource.secondary.password=root
spring.datasource.secondary.driver-class-name=com.mysql.cj.jdbc.Driver
spring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
spring.http.encoding.force=true
複製代碼
須要咱們注意的是,Springboot2.0 在配置數據庫鏈接的時候須要使用jdbc-url,若是隻使用url的話會報json
jdbcUrl is required with driverClassName.錯誤。瀏覽器
新建一個配置類PrimaryDataSourceConfig,用於配置咱們的主數據庫相關的bean,代碼以下:session
@Configuration
@MapperScan(basePackages = "com.jdkcb.mybatisstuday.mapper.one", sqlSessionFactoryRef = "PrimarySqlSessionFactory")//basePackages:接口文件的包路徑
public class PrimaryDataSourceConfig {
@Bean(name = "PrimaryDataSource")
// 表示這個數據源是默認數據源
@Primary//這個必定要加,若是兩個數據源都沒有@Primary會報錯
@ConfigurationProperties(prefix = "spring.datasource.primary")//咱們配置文件中的前綴
public DataSource getPrimaryDateSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "PrimarySqlSessionFactory")
@Primary
public SqlSessionFactory primarySqlSessionFactory(@Qualifier("PrimaryDataSource") DataSource datasource) throws Exception {
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(datasource);
bean.setMapperLocations(
new PathMatchingResourcePatternResolver().getResources("classpath*:mapping/one/*.xml"));
return bean.getObject();// 設置mybatis的xml所在位置
}
@Bean("PrimarySqlSessionTemplate")
// 表示這個數據源是默認數據源
@Primary
public SqlSessionTemplate primarySqlSessionTemplate( @Qualifier("PrimarySqlSessionFactory") SqlSessionFactory sessionfactory) {
return new SqlSessionTemplate(sessionfactory);
}
}
複製代碼
註解說明:
@MapperScan :配置mybatis的接口類放的地方
@Primary :表示使用的是默認數據庫,這個一個要加,不然會由於不知道哪一個數據庫是默認數據庫而報錯
@ConfigurationProperties:讀取application.properties中的配置參數映射成爲一個對象,其中prefix表示參數的前綴
大功告成~ ~ 了嗎?並無,而後配置咱們的第二個數據源的配置類,代碼以下:
@Configuration
@MapperScan(basePackages = "com.jdkcb.mybatisstuday.mapper.two", sqlSessionFactoryRef = "SecondarySqlSessionFactory")
public class SecondaryDataSourceConfig {
@Bean(name = "SecondaryDataSource")
@ConfigurationProperties(prefix = "spring.datasource.secondary")
public DataSource getSecondaryDataSource() {
return DataSourceBuilder.create().build();
}
@Bean(name = "SecondarySqlSessionFactory")
public SqlSessionFactory secondarySqlSessionFactory(@Qualifier("SecondaryDataSource") DataSource datasource) throws Exception {
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(datasource);
bean.setMapperLocations(
new PathMatchingResourcePatternResolver().getResources("classpath*:mapping/two/*.xml"));
return bean.getObject();// 設置mybatis的xml所在位置
}
@Bean("SecondarySqlSessionTemplate")
public SqlSessionTemplate secondarySqlSessionTemplate( @Qualifier("SecondarySqlSessionFactory") SqlSessionFactory sessionfactory) {
return new SqlSessionTemplate(sessionfactory);
}
複製代碼
剩下的就是編寫咱們相應的xml文件和接口類了,代碼以下:
@Component
@Mapper
public interface PrimaryUserMapper {
List<User> findAll();
}
@Component
@Mapper
public interface SecondaryUserMapper {
List<User> findAll();
}
複製代碼
相關的xml文件以下:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jdkcb.mybatisstuday.mapper.one.PrimaryUserMapper">
<select id="findAll" resultType="com.jdkcb.mybatisstuday.pojo.User">
select * from sys_user;
</select>
</mapper>
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jdkcb.mybatisstuday.mapper.two.SecondaryUserMapper">
<select id="findAll" resultType="com.jdkcb.mybatisstuday.pojo.User">
select * from sys_user2;
</select>
</mapper>
複製代碼
注:其中xml文件在本實例中目錄爲:resources/mapping
編寫一個Controller用於測試,由於是測試實例且代碼相對來講較爲簡單,因此這裏就不寫Service層了。
代碼以下:
@RestController
public class UserController {
@Autowired
private PrimaryUserMapper primaryUserMapper;
@Autowired
private SecondaryUserMapper secondaryUserMapper;
@RequestMapping("primary")
public Object primary(){
List<User> list = primaryUserMapper.findAll();
return list;
}
@RequestMapping("secondary")
public Object secondary (){
List<User> list = secondaryUserMapper.findAll();
return list;
}
}
複製代碼
在瀏覽器分別輸入:http://127.0.0.1:8080/primary 和 http://127.0.0.1:8080/secondary
結果以下:
[{"user_id":1,"user_name":"張三","user_age":25}] //primary
[{"user_id":1,"user_name":"李四","user_age":30}] //secondary
複製代碼
到此,Springboot結合mybatis配置多數據源就大功告成啦。
最後的最後,你們好,我是韓數,哼,關注我,有你好果子吃(叉腰)。
記得點個贊再走哦~
等一下:
相關源碼歡迎去個人github下載(歡迎star):