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

相关推荐
独孤九剑打醒他3 小时前
双层Master-Worker软硬协同调度架构:从根源解决分布式数据一致性难题
后端·嵌入式硬件·硬件架构·硬件工程
TanYYF4 小时前
spring ai入门教程二
java·人工智能·spring
SeeYa-J4 小时前
Spring IOC(Inversion of Control)
java·spring·rpc
不会c+5 小时前
02-SpringBoot配置文件
java·spring boot·后端
雨辰AI6 小时前
生产级实战:人大金仓 V9 标准化运维手册(日常巡检 + 监控告警 + 应急处置)
java·运维·数据库·后端
TeamDev6 小时前
JxBrowser 9.3.0 版本发布啦!
java·后端·c#·混合应用·jxbrowser·浏览器控件·异步媒体设备
陈随易7 小时前
Rust、Golang、MoonBit 编译成 WASM,体积和速度差距有多大?
前端·后端·程序员
IT_陈寒7 小时前
Python多线程的坑,我居然现在才踩到
前端·人工智能·后端
魏祖潇7 小时前
DDD 完整指南——AI 时代工程师的第一道秩序分水岭
人工智能·后端
长不胖的路人甲7 小时前
Redis 数据删除策略
数据库·redis·spring