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

相关推荐
zopple5 小时前
常见的 Spring 项目目录结构
java·后端·spring
cjy0001117 小时前
springboot的 nacos 配置获取不到导致启动失败及日志不输出问题
java·spring boot·后端
小江的记录本8 小时前
【事务】Spring Framework核心——事务管理:ACID特性、隔离级别、传播行为、@Transactional底层原理、失效场景
java·数据库·分布式·后端·sql·spring·面试
sheji34168 小时前
【开题答辩全过程】以 基于springboot的校园失物招领系统为例,包含答辩的问题和答案
java·spring boot·后端
卓怡学长8 小时前
m289在线交友系统
java·spring·tomcat·maven·intellij-idea·hibernate
程序员cxuan8 小时前
人麻了,谁把我 ssh 干没了
人工智能·后端·程序员
wuyikeer9 小时前
Spring Framework 中文官方文档
java·后端·spring
Victor35610 小时前
MongoDB(61)如何避免大文档带来的性能问题?
后端
Victor35610 小时前
MongoDB(62)如何避免锁定问题?
后端
wuyikeer10 小时前
Spring BOOT 启动参数
java·spring boot·后端