日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SpringBoot Mybatis動態數據源切換方案實現過程

瀏覽:5日期:2023-05-23 15:04:50

背景

最近讓我做一個大數據的系統,分析了一下,麻煩的地方就是多數據源切換抽取數據。考慮到可以跨服務器跨數據庫抽數,再整理數據,就配置了這個動態數據源的解決方案。在此分享給大家。

實現方案

數據庫配置文件

我們項目使用的是yml形式的配置文件,采用的是hikari的數據庫連接池。第一步我們自然是配置多個數據庫源頭。我們找到spring的datasource,在下方配置三個數據源。

spring: application: name: dynamicDatasource datasource: test1: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/test1?serverTimezone=GMT%2B8&characterEncoding=utf-8&useSSL=false username: root password: 123456 test2: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/test2?serverTimezone=GMT%2B8&characterEncoding=utf-8&useSSL=false username: root password: 123456 test3: driver-class-name: com.mysql.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/test3?serverTimezone=GMT%2B8&characterEncoding=utf-8&useSSL=false username: root password: 123456 hikari: leak-detection-threshold: 2000

定義數據源實體類

我們可以建立個datasourceBean文件夾專門管理數據源的實體類。

我們這里要建立三個實體類。分別對應test1,test2,test3

@Configurationpublic class Test1DataSourceBean { @Value('${spring.datasource.test1.driver-class-name}') private String test1Driver; @Value('${spring.datasource.test1.url}') private String test1Url; @Value('${spring.datasource.test1.username}') private String test1Username; @Value('${spring.datasource.test1.password}') private String test1Password; @Bean(name='test1DataSource') public DataSource test1DataSource() throws Exception{ HikariDataSource dataSource = new HikariDataSource(); dataSource.setDriverClassName(test1Driver); dataSource.setJdbcUrl(test1Url); dataSource.setUsername(test1Username); dataSource.setPassword(test1Password); return dataSource; }}

@Configurationpublic class Test2DataSourceBean { @Value('${spring.datasource.test2.driver-class-name}') private String test2Driver; @Value('${spring.datasource.test2.url}') private String test2Url; @Value('${spring.datasource.test2.username}') private String test2Username; @Value('${spring.datasource.test2.password}') private String test2Password; @Bean(name='test2DataSource') public DataSource test2DataSource() throws Exception{ HikariDataSource dataSource = new HikariDataSource(); dataSource.setDriverClassName(test2Driver); dataSource.setJdbcUrl(test2Url); dataSource.setUsername(test2Username); dataSource.setPassword(test2Password); return dataSource; }}

@Configurationpublic class Test3DataSourceBean { @Value('${spring.datasource.test3.driver-class-name}') private String test3Driver; @Value('${spring.datasource.test3.url}') private String test3Url; @Value('${spring.datasource.test3.username}') private String test3Username; @Value('${spring.datasource.test3.password}') private String test3Password; @Bean(name='test3DataSource') public DataSource test3DataSource() throws Exception{ HikariDataSource dataSource = new HikariDataSource(); dataSource.setDriverClassName(test3Driver); dataSource.setJdbcUrl(test3Url); dataSource.setUsername(test3Username); dataSource.setPassword(test3Password); return dataSource; }}

定義一個枚舉類管理數據源

public enum DatabaseType { test1('test1', 'test1'), test2('test2', 'test2'), test3('test3','test3'); private String name; private String value; DatabaseType(String name, String value){ this.name = name; this.value = value; } public String getName(){ return name; } public String getValue(){ return value; }}

定義一個線程安全的數據源容器

public class DatabaseContextHolder { private static final ThreadLocal<DatabaseType> contextHolder = new ThreadLocal<>(); public static void setDatabaseType(DatabaseType type){ contextHolder.set(type); } public static DatabaseType getDatabaseType(){ return contextHolder.get(); }}

定義動態數據源

public class DynamicDataSource extends AbstractRoutingDataSource{ protected Object determineCurrentLookupKey() { return DatabaseContextHolder.getDatabaseType(); }}

mybatis配置類

網上的很多文章配置出來都會產生數據源循環依賴的問題,這里解決了這個問題。

@Configuration@MapperScan(basePackages='cn.test.jichi', sqlSessionFactoryRef='sessionFactory')public class MybatisConfig { /** * @Description:設置動態數據源 */ @Bean(name='dynamicDataSource') @Primary public DynamicDataSource DataSource( @Qualifier('test1DataSource') DataSource test1DataSource, @Qualifier('test2DataSource') DataSource test2DataSource, @Qualifier('test3DataSource') DataSource test3DataSource){ Map<Object, Object> targetDataSource = new HashMap<>(); targetDataSource.put(DatabaseType.test1, test1DataSource); targetDataSource.put(DatabaseType.test2, test2DataSource); targetDataSource.put(DatabaseType.test3, test3DataSource); DynamicDataSource dataSource = new DynamicDataSource(); dataSource.setTargetDataSources(targetDataSource); dataSource.setDefaultTargetDataSource(test1DataSource); return dataSource; } /** * @Description:根據動態數據源創建sessionFactory */ @Bean(name='sessionFactory') public SqlSessionFactory sessionFactory( @Qualifier('test1DataSource') DataSource test1DataSource, @Qualifier('test2DataSource') DataSource test2DataSource, @Qualifier('test3DataSource') DataSource test3DataSource) throws Exception{ SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean(); //構造方法,解決動態數據源循環依賴問題。 sessionFactoryBean.setDataSource(this.DataSource(test1DataSource,test2DataSource, test3DataSource)); return sessionFactoryBean.getObject(); }}

示例

public void testDymnaicDatasource(){ //不切換數據源默認是自己的。 System.out.println('-----默認數據源'); DemoEntity totalCount = demoMapper.getTotalCount(); String nameCount1 = totalCount.getNameCount(); String ageCount2 = totalCount.getAgeCount(); System.out.println('nameCount:'+nameCount1); System.out.println('ageCount:'+ageCount2); //數據源切換為branch System.out.println('-----數據源為test2'); DynamicDataSourceUtils.chooseBranchDataSource(); Integer nameCount = demoMapper.getNameCount(); Integer ageCount = demoMapper.getAgeCount(); System.out.println('nameCount:'+nameCount); System.out.println('ageCount:'+ageCount); //數據源為basic System.out.println('-----數據源為test3'); DynamicDataSourceUtils.chooseBasicDataSource(); Integer ageCount1 = demoMapper.getAgeCount(); System.out.println('ageCount:'+ageCount1); }

總結

至此實現了多數據源的動態切換。可以在同一個方法里面進行操作多個數據源。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品一区三区三区在线观看| 国产精品黑丝在线播放| 欧美三区四区| 亚洲不卡av不卡一区二区| 国精品一区二区| 性色一区二区| 日韩高清不卡在线| 精品视频99| 亚洲www啪成人一区二区| 免费av一区二区三区四区| 99热免费精品| 亚洲精华国产欧美| 美女网站久久| 欧美一区网站| 久久精品天堂| 99久久99视频只有精品| 亚洲在线久久| 国产福利一区二区三区在线播放| 精品久久不卡| 亚洲精华国产欧美| 国产乱子精品一区二区在线观看| 精品资源在线| 99视频一区| 麻豆国产精品| 午夜国产一区二区| 国产一区 二区| 欧美国产美女| 夜夜嗨网站十八久久| 欧美日韩一视频区二区| 国产高清不卡| 一区二区三区四区精品视频| 国产精品极品在线观看| 蜜桃tv一区二区三区| 91精品视频一区二区| 亚洲黄色中文字幕| 日韩中文一区二区| 欧美精品高清| 国产视频一区二| 国产99精品| 国产精品一页| 影音先锋久久精品| 国产福利片在线观看| 免播放器亚洲| 精品理论电影在线| 亚洲图片久久| 日韩欧美一区二区三区在线观看| 亚洲精品高潮| 国产综合色区在线观看| 午夜亚洲福利| 亚洲二区视频| 国产精品极品在线观看| 欧美网站在线| av高清不卡| 国产精品蜜月aⅴ在线| 欧美日韩国产一区二区三区不卡| 美女性感视频久久| 成人av二区| 国产一区二区三区视频在线| 综合在线一区| 日韩专区精品| 日韩激情中文字幕| 国产手机视频一区二区 | 国产精品羞羞答答在线观看| 九一成人免费视频| 福利欧美精品在线| 国产精品一区二区精品视频观看 | 精品久久精品| 欧美一区二区三区久久精品| 中文国产一区| 亚洲特色特黄| 国产精品久久久久av电视剧| 国产精品嫩草影院在线看| 亚洲欧美日韩国产| 久久久水蜜桃av免费网站| 精品国产乱码久久久久久樱花| 日韩国产欧美在线播放| 久久福利一区| 女人天堂亚洲aⅴ在线观看| 国产h片在线观看| 国产精品网站在线看| 蜜桃视频一区二区三区| 五月天久久久| 亚洲成人精品| аⅴ资源天堂资源库在线| 免费视频一区二区三区在线观看 | www.51av欧美视频| 精品欧美日韩精品| 久久影视三级福利片| 日韩av中文字幕一区| 亚洲欧美日本国产| 日韩欧美中文字幕在线视频| 亚洲久草在线| 日本欧美韩国一区三区| 日韩精品国产精品| 日韩制服丝袜先锋影音| 日韩制服丝袜av| 中文字幕av一区二区三区四区| 亚洲一区中文| 另类激情亚洲| 亚洲精品福利| 国产欧美在线观看免费| 国产精品第一| 国产精品二区不卡| 久久久夜精品| 亚洲少妇自拍| 日韩精品视频网| 国产精品传媒麻豆hd| 国产成人久久| 久久激情中文| 99久久亚洲精品| 日韩视频久久| 亚洲精品伊人| 欧美国产专区| 日韩精品第一区| 中文欧美日韩| 欧美日韩一区自拍| av免费不卡国产观看| 国产一区欧美| 日韩精品免费一区二区夜夜嗨 | 91p九色成人| 国产一区二区三区天码| 欧美中文一区二区| 视频一区在线视频| 国产精品亲子伦av一区二区三区| 国产在线不卡一区二区三区| 欧美片第1页| 成人在线黄色| 欧美日韩日本国产亚洲在线| 日韩av一区二| 欧美三级精品| 亚洲tv在线| 国内精品亚洲| 性欧美69xoxoxoxo| 日韩福利在线观看| 日韩久久精品| 中文字幕一区二区三区在线视频| 国产伦一区二区三区| 福利片在线一区二区| 国产视频欧美| 精品91福利视频| 美女毛片一区二区三区四区| 久久精品超碰| 久久国产日韩| 日本午夜免费一区二区| 亚洲伊人av| 亚洲精品影视| 久久三级福利| 欧美91在线| 性欧美长视频| 亚洲天堂一区二区| 久久狠狠亚洲综合| 石原莉奈一区二区三区在线观看| 国产精品亚洲成在人线| 黄色国产精品| 精品一区二区三区视频在线播放| 午夜免费一区| 三上亚洲一区二区| 久久xxxx精品视频| 色在线中文字幕| 日本三级亚洲精品| 久久影院一区| 久草精品视频| 日韩av一级片| 亚洲一区观看| 亚洲精品.com| 精品视频在线你懂得| 亚洲毛片视频| 亚洲h色精品| 国产一区二区三区网| 日韩毛片一区| 国产精品外国| 91精品国产调教在线观看| 久久精品系列| 国产精品一在线观看| 久色成人在线| 四虎884aa成人精品最新| 国产精品国产三级在线观看| 亚洲免费成人av在线| 久久一级电影| 国产粉嫩在线观看| 免费日韩成人| 日本午夜精品| 国产免费成人| 激情久久婷婷| 天堂√8在线中文| 精品日韩一区| 国产精品男女| 国产欧美日韩影院| 日欧美一区二区| 亚洲区第一页| 免费在线欧美视频| 99在线|亚洲一区二区| 天堂8中文在线最新版在线| 久久精品亚洲一区二区| 国产欧美91| 欧美一级二级视频| 91伊人久久| 日韩美女国产精品| 亚洲午夜国产成人| 亚洲毛片在线免费|