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

在SpringBoot中利用nacos对数据源进行动态刷新

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

在SpringBoot中利用nacos对数据源进行动态刷新

一、重写DruidAbstractDataSource类

这里为什么要重写这个类:因为DruidDataSource数据源在初始化后,就不允许再重新设置数据库的url和userName

注意:类所在的包名必须为 com.alibaba.druid.pool

 

public void setUrl(String jdbcUrl) {
if (StringUtils.equals(this.jdbcUrl, jdbcUrl)) {
return;

}

// 重写的时候,需要将这个判断注释掉,否则会报错

// if (inited) {
// throw new UnsupportedOperationException();

// }

if (jdbcUrl != null) {
jdbcUrl = jdbcUrl.trim();

}

this.jdbcUrl = jdbcUrl;

// if (jdbcUrl.startsWith(ConfigFilter.URL_PREFIX)) {
// this.filters.add(new ConfigFilter());

// }

}

public void setUsername(String username) {
if (StringUtils.equals(this.username, username)) {
return;

}

// 重写的时候,需要将这个判断注释掉,否则会报错

// if (inited) {
// throw new UnsupportedOperationException();

// }

this.username = username;

}

注意: 重写后包路径不能变, 这样就能优先加载自己重写的类

二、配置数据源并动态地从nacos获取配置信息
package com.mp.demo.config;

import com.alibaba.druid.pool.DruidDataSource;
import lombok.Data;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Slf4j
@Configuration
@RefreshScope //必须要加这个注解,该注解的作用是nacos配置更新后,能马上获取最新的值
@Data
public class DruidConfiguration
{
  @Value("${spring.datasource.url}")
  private String dbUrl;

  @Value("${spring.datasource.username}")
  private String username;

  @Value("${spring.datasource.password}")
  private String password;

  @Value("${spring.datasource.driver-class-name}")
  private String driverClassName;

  @Bean
  @RefreshScope
  public DruidDataSource dataSource()
  {
    DruidDataSource datasource = new DruidDataSource();
    datasource.setUrl(this.dbUrl);
    datasource.setUsername(username);
    datasource.setPassword(password);
    datasource.setDriverClassName(driverClassName);
    return datasource;
  }
}
三、手动刷新数据源

在controller层写一个接口, 每次nacos中更改配置后,手动请求一下该接口,就能切换数据源

 @GetMapping("/refresh")
  public String refresh() throws SQLException
  {
    DruidDataSource master = SpringUtils.getBean("dataSource");
    master.setUrl(druidConfiguration.getDbUrl());
    master.setUsername(druidConfiguration.getUsername());
    master.setPassword(druidConfiguration.getPassword());
    master.setDriverClassName(druidConfiguration.getDriverClassName());
    master.restart();
    return "mysql: " + jdbcUrl+"----------"+druidConfiguration.getDbUrl();
  }

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/318546.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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