若依Springboot项目Druid不停机更换数据源

简介: 若依Springboot项目Druid不停机更换数据源

@[TOC]

1 不停机通过接口切换数据源

@GetMapping("/updateDruidProperty")
@Anonymous
    public AjaxResult updateProperty(){
   
   
        DruidDataSource dataSource = SpringUtils.getBean("masterDataSource");
        try {
   
   
            Properties properties = new Properties();
            // 这里是测试写法,具体的value可以通过请求参数传递过来
            // 例如 http://localhost:8080/test?druid.url="...."&&druid.username="...."&&druid.password="...."
            properties.setProperty("druid.url","jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8");
            properties.setProperty("druid.username","root");
            properties.setProperty("druid.password","root");
            dataSource.restart(properties);
        } catch (SQLException throwables) {
   
   
            throwables.printStackTrace();
        }
        return AjaxResult.success();
    }

2 随便写个接口测试

@GetMapping("/insertUser")
    @Anonymous
    public AjaxResult insertUser(){
   
   
        SysUser user = new SysUser();
        user.setUserName("胡云峰");
        user.setNickName("logicfeng");
        userService.insertUser(user);
        String password = configurableEnvironment.getProperty("spring.datasource.druid.master.password");
        return AjaxResult.success(password);
    }

3 使用apifox测试

3.1 切换数据源前新增数据

  • 发起请求
    在这里插入图片描述
  • 测试结果
    在这里插入图片描述

    3.2 切换数据源

  • 发起请求
    在这里插入图片描述

    3.3 测试新的数据源新增用户

  • 发起请求
    在这里插入图片描述
  • 测试结果
    在这里插入图片描述
目录
相关文章
|
2月前
|
Java 数据库连接 Maven
springBoot:项目建立&配置修改&yaml的使用&resource 文件夹(二)
本文档介绍了如何创建一个基于Maven的项目,并配置阿里云仓库、数据库连接、端口号、自定义启动横幅及多环境配置等。同时,详细说明了如何使用YAML格式进行配置,以及如何处理静态资源和模板文件。文档还涵盖了Spring Boot项目的`application.properties`和`application.yaml`文件的配置方法,包括设置数据库驱动、URL、用户名、密码等关键信息,以及如何通过配置文件管理不同环境下的应用设置。
286 1
|
1月前
|
Java 应用服务中间件
SpringBoot获取项目文件的绝对路径和相对路径
SpringBoot获取项目文件的绝对路径和相对路径
104 1
SpringBoot获取项目文件的绝对路径和相对路径
|
1月前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
57 8
|
1月前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
44 2
|
2月前
|
JavaScript 前端开发 Java
解决跨域问题大集合:vue-cli项目 和 java/springboot(6种方式) 两端解决(完美解决)
这篇文章详细介绍了如何在前端Vue项目和后端Spring Boot项目中通过多种方式解决跨域问题。
402 1
解决跨域问题大集合:vue-cli项目 和 java/springboot(6种方式) 两端解决(完美解决)
|
1月前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
57 2
|
1月前
|
前端开发 Java Spring
SpringBoot项目thymeleaf页面支持词条国际化切换
SpringBoot项目thymeleaf页面支持词条国际化切换
76 2
|
1月前
|
JSON Java 数据库
SpringBoot项目使用AOP及自定义注解保存操作日志
SpringBoot项目使用AOP及自定义注解保存操作日志
53 1
|
2月前
|
Java Maven Android开发
eclipse如何导入springboot项目
本文介绍了如何在Eclipse中导入Spring Boot项目。
47 1
eclipse如何导入springboot项目
|
1月前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。