SpringCloud使用Nacos作为配置中心实现动态数据源切换

一、Nacos-Server

了解Nacos可以直接阅读官方文档

使用Nacos,我们需要有Nacos-Server,此处就不使用官方提供的release版本了,而是自己编译,因为本来就是Java开发的,所以对于Javaer来说也没啥难度!

sh 复制代码
git clone https://github.com/alibaba/nacos.git
cd nacos
git checkout 2.2.4
mvn -Prelease-nacos -Dmaven.test.skip=true clean install -U

只需要四行命令,即可实现编译,要求编译时有网络环境。

之后,进入到distribution/target,即可获取压缩包。

解压后,进入bin目录,执行命令启动nacos服务即可

sh 复制代码
startup.cmd -m standalone

二、SpringCloud

2.1 版本对应关系

官方文档里倒是提到了springboot、springcloud、springcloudalibaba之间的对应关系,但是由于文档更新存在不及时问题。因此,版本对应关系,可以直接使用阿里提供的脚手架

2.2 实现动态数据源切换

"Talk is cheap. Show me the code.",直接上源码

核心在于@RefreshScope这个注解,被该注解标识后,表示这个Bean在运行时是可刷新的。并且所有基于该Bean的依赖也会被刷新,这些复杂的工作都是springcloud做的,开发者不需要关心。

整体流程如图所示

至于Nacos如何配置,参照Nacos 融合 Spring Cloud,成为注册配置中心 | Nacos

展示一下最后的成果。

三、参考

alibaba/nacos: an easy-to-use dynamic service discovery, configuration and service management platform for building cloud native applications.

Nacos 快速开始 | Nacos

Nacos 融合 Spring Cloud,成为注册配置中心 | Nacos

Cloud Native App Initializer

Cloud Native App Initializer

相关推荐
__土块__1 天前
一次 Spring 事务传播机制源码走读:从误用 @Transactional 到理解嵌套事务的边界
spring·threadlocal·编程式事务·@transactional·事务传播·源码走读·requires_new
Java面试题总结1 天前
Spring - Bean 生命周期
java·spring·rpc
二月夜1 天前
Spring循环依赖深度解析:从三级缓存原理到跨环境“灵异”现象
java·spring
nbwenren1 天前
Springboot中SLF4J详解
java·spring boot·后端
helx821 天前
SpringBoot中自定义Starter
java·spring boot·后端
rleS IONS1 天前
SpringBoot获取bean的几种方式
java·spring boot·后端
lifewange1 天前
Go语言-开源编程语言
开发语言·后端·golang
白毛大侠1 天前
深入理解 Go:用户态和内核态
开发语言·后端·golang
九皇叔叔1 天前
003-SpringSecurity-Demo 统一响应类
java·javascript·spring·springsecurity
王码码20351 天前
Go语言中的数据库操作:从sqlx到ORM
后端·golang·go·接口