Springboot+mybatis+druid 配置多數(shù)據(jù)源

application.yml配置文件
#durid數(shù)據(jù)庫連接池設(shè)置
spring:
  profiles:
    ##此處引入配置其他數(shù)據(jù)源配置文件
    include: dev-datasource
  aop:
    proxy-target-class: true
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.jdbc.Driver
    jdbc-url: jdbc:mysql://127.0.0.1:3306/primarydatasource?useUnicode=true&characterEncoding=utf-8&useSSL=false
    username: root
    password: 123456
    # 下面為連接池的補(bǔ)充設(shè)置胎围,應(yīng)用到上面所有數(shù)據(jù)源中
    # 初始化大小,最小,最大
    initialSize: 5
    minIdle: 5
    maxActive: 15
    # 配置獲取連接等待超時(shí)的時(shí)間
    maxWait: 60000
    # 配置間隔多久才進(jìn)行一次檢測,檢測需要關(guān)閉的空閑連接鹃祖,單位是毫秒
    timeBetweenEvictionRunsMillis: 60000
    minEvictableIdleTimeMillis: 300000
    validationQuery: SELECT 1 FROM DUAL
    testWhileIdle: true
    testOnBorrow: false
    testOnReturn: false
    # 打開PSCache宅广,并且指定每個(gè)連接上PSCache的大小
    poolPreparedStatements: true
    # 配置監(jiān)控統(tǒng)計(jì)攔截的filters,去掉后監(jiān)控界面sql無法統(tǒng)計(jì)目尖,'wall'用于防火墻
    maxPoolPreparedStatementPerConnectionSize: 20
    filters: stat,wall,log4j2
    # 通過connectProperties屬性來打開mergeSql功能;慢SQL記錄
    connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
    # 合并多個(gè)DruidDataSource的監(jiān)控?cái)?shù)據(jù)
    useGlobalDataSourceStat: true
    druid:
      remove-abandoned: true
      remove-abandoned-timeout: 180
      log-abandoned: true
application-dev-datasource.yml配置文件 (個(gè)人習(xí)慣單獨(dú)寫了個(gè)yml扎运,再增加數(shù)據(jù)源可以在這里配置)
## 第二個(gè)數(shù)據(jù)源
spring:
  datasource2:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.jdbc.Driver
    jdbc-url: jdbc:mysql://127.0.0.1:3306/seconddatasource?useUnicode=true&characterEncoding=utf-8&useSSL=false
    username: root
    password: 123456
主數(shù)據(jù)源配置代碼
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
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.jdbc.datasource.DataSourceTransactionManager;
import tk.mybatis.spring.annotation.MapperScan;

import javax.sql.DataSource;

@Primary
@Configuration
@MapperScan(basePackages = "com.btwl.primary.mapper" , sqlSessionFactoryRef = "primarySqlSessionFactory")
public class PrimaryDataSource {

    @Bean(name = "DataSource_primary")
    @Primary
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource primaryDataSource(){
        return DataSourceBuilder.create().build();
    }

    @Bean(name = "primarySqlSessionFactory")
    @Primary
    public SqlSessionFactory primarySqlSessionFactory(@Qualifier("DataSource_primary") DataSource dataSource)
            throws Exception{
        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
        bean.setDataSource(dataSource);
        return bean.getObject();
    }

    @Bean(name = "primaryTransactionManager")
    @Primary
    public DataSourceTransactionManager primaryTransactionManager(@Qualifier("DataSource_primary") DataSource dataSource){
        return new DataSourceTransactionManager(dataSource);
    }

    @Bean(name = "primarySqlSessionTemplate")
    @Primary
    public SqlSessionTemplate primarySqlSessionTemplate(@Qualifier("primarySqlSessionFactory") SqlSessionFactory sqlSessionFactory){
        return new SqlSessionTemplate(sqlSessionFactory);
    }
}
第二個(gè)數(shù)據(jù)源配置代碼
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
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.jdbc.datasource.DataSourceTransactionManager;
import tk.mybatis.spring.annotation.MapperScan;

import javax.sql.DataSource;

@Configuration
@MapperScan(basePackages = "com.btwl.second.mapper" , sqlSessionFactoryRef = "secondSqlSessionFactory")
public class SecondDataSource {

    @Bean(name = "DataSource_second")
    @ConfigurationProperties(prefix = "spring.datasource1")
    public DataSource secondDataSource(){
        return DataSourceBuilder.create().build();
    }

    @Bean(name = "secondSqlSessionFactory")
    public SqlSessionFactory secondSqlSessionFactory(@Qualifier("DataSource_second") DataSource dataSource)
            throws Exception{
        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
        bean.setDataSource(dataSource);
        return bean.getObject();
    }

    @Bean(name = "secondTransactionManager")
    public DataSourceTransactionManager secondTransactionManager(@Qualifier("DataSource_second") DataSource dataSource){
        return new DataSourceTransactionManager(dataSource);
    }

    @Bean(name = "secondSqlSessionTemplate")
    public SqlSessionTemplate secondSqlSessionTemplate(@Qualifier("secondSqlSessionFactory") SqlSessionFactory sqlSessionFactory){
        return new SqlSessionTemplate(sqlSessionFactory);
    }
}
@Primary:指定為默認(rèn)數(shù)據(jù)源瑟曲,沒有該注解會報(bào)錯(cuò),系統(tǒng)找不到默認(rèn)數(shù)據(jù)源
@MapperScan:掃描指定包的mapper作為對應(yīng)數(shù)據(jù)源豪治,建議每個(gè)數(shù)據(jù)源都用不同的包區(qū)分
@Qualifier:與@Autowired類似洞拨,用作區(qū)分如果存在多個(gè)實(shí)現(xiàn)類要指定要注入哪個(gè) 參數(shù)為指定Bean的name
spring-database-jdbc-url 不要寫成 spring-database-url 會報(bào)錯(cuò) exception : jdbcUrl is required with driverClassName,(嗯负拟,不知道為啥

業(yè)務(wù)邏輯代碼就不放了跟其他的沒什么區(qū)別烦衣,再添加數(shù)據(jù)源的話就按以上配置再加一個(gè)就好了,

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末掩浙,一起剝皮案震驚了整個(gè)濱河市花吟,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌厨姚,老刑警劉巖衅澈,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異谬墙,居然都是意外死亡今布,警方通過查閱死者的電腦和手機(jī)经备,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來部默,“玉大人弄喘,你說我怎么就攤上這事∷ξ” “怎么了蘑志?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長贬派。 經(jīng)常有香客問我急但,道長,這世上最難降的妖魔是什么搞乏? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任波桩,我火速辦了婚禮,結(jié)果婚禮上请敦,老公的妹妹穿的比我還像新娘镐躲。我一直安慰自己,他們只是感情好侍筛,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布萤皂。 她就那樣靜靜地躺著,像睡著了一般匣椰。 火紅的嫁衣襯著肌膚如雪裆熙。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天禽笑,我揣著相機(jī)與錄音入录,去河邊找鬼。 笑死佳镜,一個(gè)胖子當(dāng)著我的面吹牛僚稿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蟀伸,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蚀同,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了望蜡?” 一聲冷哼從身側(cè)響起唤崭,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤拷恨,失蹤者是張志新(化名)和其女友劉穎脖律,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體腕侄,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡小泉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年芦疏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片微姊。...
    茶點(diǎn)故事閱讀 40,015評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡酸茴,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出兢交,到底是詐尸還是另有隱情薪捍,我是刑警寧澤,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布配喳,位于F島的核電站酪穿,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏晴裹。R本人自食惡果不足惜被济,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望涧团。 院中可真熱鬧只磷,春花似錦、人聲如沸泌绣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽阿迈。三九已至畏陕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間仿滔,已是汗流浹背惠毁。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留崎页,地道東北人鞠绰。 一個(gè)月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像飒焦,于是被迫代替她去往敵國和親蜈膨。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評論 2 355

推薦閱讀更多精彩內(nèi)容