nacos环境切换_springboot集成Nacos实现多环境动态配置nacos 阿⾥旗下的开源项⽬,⼀个更易于构建云原⽣应⽤的动态服务发现、配置管理和服务管理平台。随着我国科技的进步,越来越多的开源技术来⾃我骄傲的中国,以前要了解某项技术除了查看国内⼤佬博主的⽂章就是硬着头⽪去看官⽅的英⽂⽂档。现在好多了,国内的开源项⽬官⽅⽂档⾸先就得有中⽂版的,但是,这nacos的⼿册写的略显敷衍 。
最近上线了⼀个项⽬,上线之前整理⽣产环境的配置真是让⼈头⼤,⽣怕有遗漏或者填错的地⽅,如果在现场配置的有问题,改正后还得重启服务才能⽣效,这不,对⽅把我们的端⼝少写了个数字,某功能出现问题,⽩天他们⼜不能重启,只能等到晚上解决。如果能够使⽤
nacos作为动态的配置中⼼,直接改配置不需要重启就可以解决了。
本章内容介绍的是spring-boot集成nacos ,不是spring-cloud ,导的包不⼀样使⽤起来也有点差异。
nacos服务端
⾸先下载安装nacos服务端
启动⽅法参考Nacos 快速⼊门
创建命名空间
登陆后左侧导航栏选择命名空间,右上⾓创建命名空间,分别创建dev 和prod 作为开发和⽣产环境的配置,不同空间互相隔离。⽤来区分环境⾮常合适。
创建配置⽂件
左侧导航栏>配置管理-配置列表
创建配置⽂件需要填写DataId 和GroupId,以及配置内容
注意:dataId必须以⽂件类型结尾
spring-boot集成nacos配置中⼼
添加nacos配置中⼼的依赖
com.alibaba.boot
nacos-config-spring-boot-starter
${latest.version}
springboot 版本 2.3.2.RELEASE
nacos-config 版本 0.2.7
yml配置nacos服务端地址和命名空间
创建配置⽂件l 和l
根据在nacos服务端控制台创建的两个命名空间的ID分别填写到开发环境和⽣产环境的yml⽂件⾥lnacos:
config:
namespace: 133c9c90-6d9c-45cd-8067-06f853607940
server-addr: 127.0.0.lnacos:
config:
namespace: 72008218-19b0-4960-ab44-a0cbdd8097a0
server-addr: 127.0.0.1:8848
启动类配置dataId 和 groupId
@NacosPropertySource注解填写dataId 和 groupId ,autoRefreshed = true 表⽰动态刷新的总开关,ture:开启,默认是false.
读取多个配置⽂件就写多个注解,如果两个配置⽂件中有相同的配置,排在上⾯的注解读取的配置内容优先级最⾼。
同⼀个配置⽂件可以被同空间的应⽤共享。@SpringBootApplication
@NacosPropertySource(dataId = "mashu-demo.yaml", autoRefreshed = true, groupId = "USER_GROUP")
@NacosPropertySource(dataId = "dashu-demo.yaml", autoRefreshed = true, groupId = "USER_GROUP")
注⼊配置内容
@NacosValue注解获取配置内容,autoRefreshed = true 表⽰开启动态刷新@NacosValue(value = "${name}", autoRefreshed = true)
private String name;
不同环境的启动⽅法
杨可涵命令⾏读取不同环境的配置:
启动参数根据-Dspring.profiles.active=dev或-Dspring.profiles.active=prod切换开发和⽣产环境
读取l 还是 l 依据是"-"后⾯的单词,即: dev/prod
开发⼯具读取不同环境的配置:
idea 开发⼯具是打开设置Edit configurations 选项,在Actice profile 后⾯填写dev或者prod
⾄此多环境动态配置完成。
数据持久化
眼睛的睛怎么组词为了保证数据的安全性,nacos还⽀持将数据同步到数据库。
这个需要在nacos服务端配置,在下载的nacos安装包⾥⾯nacos-server-1.2.1\nacos\conf\nacos-mysql.sql有msyql初始化的sql脚本。
根据实际情况修改配置⽂件nacos-server-1.2.1\nacos\conf\application.propertiesspring.datasource.platform=mysql六级作文模版
### Count of DB:
db.num=1
### Connect URL of DB:
读取配置文件失败db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?
characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456
注意:如果之前没有做持久化,做了持久化之后会把之前的配置⼲掉。
java SDK
nacos还⽀持java客户端对配置内容的操作和配置变更的监听。
1.导包:
com.alibaba.nacos
nacos-client
1.2.0
2.根据ip和命名空间获取配置⽂件对象ConfigServiceString serverAddr = "127.0.0.1:8848";
String namespace = "72008218-19b0-4960-ab44-a0cbdd8097a0";
Properties properties = new Properties();
properties.put("serverAddr", serverAddr);
properties.put("namespace", namespace);
ConfigService configService = ateConfigService(properties);
configService对象有⼏个常⽤的⽅法:
String groupId = "USER_GROUP";
String content = Config(dataId, groupId, 5000);
2.publishConfig()发布配置String content = "name: mashu";
configService.publishConfig(dataId, group, content);
4.addListener()添加监听Listener listener = new Listener() {
@Override
public void receiveConfigInfo(String configInfo) {
System.out.println("变更后读取到的配置内容:" + "\r\n" + configInfo);
}
艺声入伍@Override
public Executor getExecutor() {
return null;
}
configService.addListener(dataId, groupId, listener);
以上配置内容的获取,添加,删除,监听都是全量的。
遇到问题
nacos对于已经jasypt加密的数据正常读取但是不能够动态刷新,甚⾄它⽗节点以下的兄弟节点没有加密的属性都会丧失动态刷新的功能。重启项⽬才能读到最新的数据。
猜测:nacos 第⼀次能够读到加密的数据是解密后的可以理解,启动参数有解密的密钥,应该是解密后naocs读取的,但是更新加密的字段nacos应该做不到,它没有密钥。nacos为了防⽌更新加密的数
据失败,它就让加密的数据失去动态更新的能⼒。阎学晶简历
困惑:我将原本加密的属性包括它⽗节点下⾯节点所有加密的属性都改成了⾮加密,重启项⽬后发现依然不能动态刷新!不能理解这种"记仇"现象,即使我重启nacos服务端也不能解决。
优缺点:单说nacos的配置管理功能
优点:⽀持动态刷新
⽀持共享配置⽂件,相同配置,配置在上⾯的优先级最⾼。
有历史记录,可回滚
每次修改有⽂件对⽐功能,降低出错率
⽀持Java代码的配置变更监听,内容的获取,添加,删除,不过都是全量缺点:不⽀持加密属性的动态刷新
对配置变更监听,内容的获取,添加,删除都是全量的
对nacos了解甚浅,有些理解可能有误差。如有错误请指出,感激不尽。
发布评论