IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SpringBoot 实现多数据源 -> 正文阅读

[Java知识库]SpringBoot 实现多数据源

双数据源实现

01 添加必要的依赖

  • spring-boot-starter
  • mybatis-plus-boot-starter
  • dynamic-datasource-spring-boot-starter # 配置动态数据源
  • druid-spring-boot-starter # 阿里的数据库连接池
  • 数据库驱动
  • lombok
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    
	<dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-boot-starter</artifactId>
        <version>3.5.1</version>
    </dependency>
    <!-- <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <scope>runtime</scope>
    </dependency>-->
    <dependency>
        <groupId>com.microsoft.sqlserver</groupId>
        <artifactId>sqljdbc4</artifactId>
        <version>4.0</version>
    </dependency>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid-spring-boot-starter</artifactId>
        <version>1.1.20</version>
    </dependency>
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
        <version>2.5.6</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.20</version>
        <scope>provided</scope>
    </dependency>
</dependencies>

02 配置各数据源的连接字符串

DruidDataSourceAutoConfigure会注入一个DataSourceWrapper,它会在原生的spring.datasource下查找数据库的连接信息;而动态数据源的连接配置是在 dynamic 下,因此需要排除 DruidDataSourceAutoConfigure,否则会报错。

排除方式有两种:

  1. 在项目启动类排除。

    @SpringBootApplication(exclude = DruidDataSourceAutoConfigure.class)
    public class Application {
      public static void main(String[] args) { SpringApplication.run(Application.class, args); }
    }
    
  2. 在配置文件排除。

    server:
      port: 8080 #服务端口
    spring:
      datasource:
        dynamic:
          primary: DB_SqlServer_CS #默认的主数据库
          datasource:
            DB_SqlServer_ZS:
              url: jdbc:sqlserver://10.20.7.50:1433;DatabaseName=measure
              username: sa
              password: dxyl
              driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
            DB_SqlServer_CS:
              url: jdbc:sqlserver://58.34.1.32:10202;DatabaseName=measure
              username: sa
              password: qAZ123.0
              driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
          druid:
            initial-size: 1
            max-active: 20
            min-idle: 1
            max-wait: 60000
      autoconfigure:
        exclude:  com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure # 去除druid配置
        
    # 从classPath路径下扫描xml文件
    mybatis-plus:
      mapper-locations: classpath*:*.xml
    

03 非默认数据库的service / mapper添加 @DS 注解

  • @DS 可以注解在方法和类上,同时存在,那么方法注解优先于类注解。
  • 不要同时在servicemapper上添加注解。
// 默认操作测试库
@Mapper
public interface Tpcca01Mapper extends BaseMapper<Tpcca01> {

    String getLatestRecTime();

    // 操作正式库
    @DS("DB_SqlServer_ZS")
    List<Tpcca01> mySelectList(@Param("ew") LambdaQueryWrapper<Tpcca01> wrapper);
}

实操过程中出现的问题

The server selected protocol version TLS10 is not accepted by client preferences [TLS13, TLS12]”
方法1:
找到jdk下的jre,之后按照下图路径找到java.security
删除jdk.tls.disabledAlgorithms 中的 TLSv1、TLSv1.1、3DES_EDE_CBC即可

方法2:
在启动类中添加

static{
        //解决JDK 8 以后禁用了TLSv1 协议的,使得无法链接老版本SqlServer的问题
        try {
            String property = Security.getProperty("jdk.tls.disabledAlgorithms");
            //删除禁用TLSv1
            String replace = property.replace("TLSv1,", "");
            Security.setProperty("jdk.tls.disabledAlgorithms",replace);
        } catch (Exception e) {
            System.out.println(e.getMessage());
        }
    }

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-10-17 12:18:51  更:2022-10-17 12:22:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/30 13:45:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码