栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

spring-boot 项目配置多数据源

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

spring-boot 项目配置多数据源

多数据源配置文件修改

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
datasource.running.databaseName=数据名1
datasource.his.databaseName=数据名2
spring.datasource.druid.running.url=jdbc:mysql://127.0.0.1:3306/${datasource.running.databaseName}?autoReconnect=true&useUnicode=yes&characterEncoding=UTF-8&useSSL=false&rewriteBatchedStatements=true&serverTimezone=Asia/Shanghai#spring.datasource.url=jdbc:mysql://127.0.0.1:3306/${datasource.databaseName}?autoReconnect=true&useUnicode=yes&characterEncoding=UTF-8&useSSL=false&rewriteBatchedStatements=true&serverTimezone=UTC
spring.datasource.druid.running.username=账号
spring.datasource.druid.running.password=密码
spring.datasource.druid.running.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.running.max-idle=10
spring.datasource.druid.running.max-wait=10000
spring.datasource.druid.running.min-idle=5
spring.datasource.druid.running.initial-size=5
spring.datasource.druid.his.url=jdbc:mysql://127.0.0.1:3306/${datasource.his.databaseName}?autoReconnect=true&useUnicode=yes&characterEncoding=UTF-8&useSSL=false&rewriteBatchedStatements=true&serverTimezone=Asia/Shanghai#spring.datasource.url=jdbc:mysql://127.0.0.1:3306/${datasource.databaseName}?autoReconnect=true&useUnicode=yes&characterEncoding=UTF-8&useSSL=false&rewriteBatchedStatements=true&serverTimezone=UTC
spring.datasource.druid.his.username=账号
spring.datasource.druid.his.password=密码
spring.datasource.druid.his.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.his.max-idle=10
spring.datasource.druid.his.max-wait=10000
spring.datasource.druid.his.min-idle=5
spring.datasource.druid.his.initial-size=5

数据源切换工具类

package com.samples.common.config;


public class DataSourceContextHolder {

    private static final ThreadLocal contextHolder = new ThreadLocal();

    
    public static void setDbType(DBTypeEnum dbTypeEnum) {
        contextHolder.set(dbTypeEnum.getValue());
    }

    
    public static String getDbType() {
        return (String) contextHolder.get();
    }

    
    public static void clearDbType() {
        contextHolder.remove();
    }
}

多个数据库的枚举

package com.samples.common.config;

public enum DBTypeEnum {
    running("running"), his("his");
    private String value;

    DBTypeEnum(String value) {
        this.value = value;
    }

    public String getValue() {
        return value;
    }
}

comfig类修改


@EnableTransactionManagement
@Configuration
@MapperScan({"com.samples.web.mapper"})
public class MybatisPlusConfig {

    
    @Bean(name = "his")
    @ConfigurationProperties(prefix = "spring.datasource.druid.his")
    public DataSource his() {
        return DruidDataSourceBuilder.create().build();
    }

    @Bean(name = "running")
    @ConfigurationProperties(prefix = "spring.datasource.druid.running")
    public DataSource running() {
        return DruidDataSourceBuilder.create().build();
    }

    @Bean
    @Primary
    public DataSource multipleDataSource(@Qualifier("running") DataSource running,
                                         @Qualifier("his") DataSource his) {
        DynamicDataSource dynamicDataSource = new DynamicDataSource();
        Map targetDataSources = new HashMap<>();
        targetDataSources.put(DBTypeEnum.running.getValue(), running);
        targetDataSources.put(DBTypeEnum.his.getValue(), his);
        dynamicDataSource.setTargetDataSources(targetDataSources);
        dynamicDataSource.setDefaultTargetDataSource(running);
        return dynamicDataSource;
    }

}
@Slf4j
public class DynamicDataSource extends AbstractRoutingDataSource {
    @Override
    protected Object determineCurrentLookupKey() {
        String datasource = DataSourceContextHolder.getDbType();
        return datasource;
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/532057.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号