SpringCloud 核心组件Nacos【配置管理&配置拉取】第4章
目录
1,Nacos配置管理
1.1:统一配置管理
1.1.1:为什么需要nacos配置中心
1.1.2:实现nacos配置中的概念
1.1.3:在nacos中添加配置文件
1.1.4.从微服务拉取配置
1.4.5 nacos 配置文件加载顺序
1,Nacos配置管理
Nacos除了可以做注册中心,同样也可以做配置管理来使用
1.1:统一配置管理
1.1.1:为什么需要nacos配置中心
一,关联服务配置修改麻烦:随着我们的微服务越来越多,我们在生产环境中可能会有数十,上百,上千的服务 ,我现在的一个配置文件需要修改,而这个配置文件可能和数十个服务都有关系这个时候我要这个一个配置文件,就要把有关联的数十个服务的配置都要进行修改
二, 关联服务重启生效麻烦:我修改完配置之后,这些修改的过的服务是不是都应该进行重启,那么在生产环境中重启这么多服务影响还是挺大的,
我们的需求是什么,我们希望这些配置文件能够实现一个统一的管理,比如我现在有十几个服务的配置文件需要修改,我不想每个都去修改去修改,而是在一个地方完成改动,并且我希望修改过的服务不需要重启,修改之后立即生效,实现服务的热更新
1.1.2:实现nacos配置中的概念
处理流程:根据在第二点引出的在一个地方进行统一修改,而要实现它怎么做到呢!我们需要实现一个配置管理服务,这个服务的作用是什么呢?这个服务会记录一些服务的核心配置放置上去,我们的微服务启动的时候,就可以去读取配置管理服务配置,再加上本地服务配置,组成完整配置去使用,将来核心配置如果要发生修改,我们不需要每个服务去修改,而是找到配置管理的服务,这个服务上进行改动,这个配置管理服务非常的智能 ,它发现改动之后它会立即通知微服务,这个时候微服务一看配置改变了,新的配置来了,微服务就赶紧完成读取新的配置,并且后续完成配置的热更新,不需要重启,这一来我们的需求就达到了!
这个配置管理服务我们将用Nacos配置管理来实现,当然我们都知道Nacos是注册中心,这个配置管理就是Nacos的第二大特点,注册找Nacos,配置管理也找Nacos
1.1.3:在nacos中添加配置文件
然后在弹出的表单中,填写配置信息:
注意:项目的核心配置,需要热更新的配置才有放到nacos管理的必要。基本不会变更的一些配置还是保存在微服务本地比较好。
DataID:配置文件的名称,但是这个名称不能像服务中都起application.yml文件名称,为什么呢!将来的所有的微服务都来找Nacos管理,大家都叫这个名字不就冲突了,所以
DataID:必须是唯一,DataID的命名方式一般是这样的,服务名称-环境.后缀名
环境:开发环境dev,测试test,均可,后缀名一般都是YAML
描述:介绍你这个配置管理是干什么的
配置内容:怎么填这个内容呢是不是说把application.yml中的所有配置复制进来就行了
不是这样的,Nacos配置管理将来这些配置是来做热更新的配置,是不是所有的配置都有热更新的配置,那肯定不是像数据库的地址,还有很多配置都不需要变,需要变得都是一些开关类型的配置:比如说我给true按照A方案执行,给false按照B方案执行,比如说服务中的一些活动的开启,我给true就开启给false就不开启了,并不是所有的配置都要进行热更新,要按照需求需要有热更新的配置我们在进行配置Nacos热更新配置
1.1.4.从微服务拉取配置
现在已经把服务的部分配置放置在Nacos配置中心做统一管理,我们的微服务就要想办法把Nacos中的配置得到,该怎么得到呢?
我们先看一下,当我们没有nacos的时候,微服务怎么执行配置文件的,首先项目启动,读取本地的application.yml文件,然后创建spring容器,把各种各样的bean放入,当然后面的步骤还有很多
我们主要关注读取本地配置文件
微服务要拉取nacos中管理的配置,并且与本地的application.yml配置合并,才能完成项目启动。
但如果尚未读取application.yml,又如何得知nacos地址呢?
因此spring引入了一种新的配置文件:bootstrap.yaml文件,会在application.yml之前被读取,流程如下:
bootstrap.yaml文件比application.yml文件优先级高,在项目启动时加载bootstrap文件,获取文件中的nacos中的地址,第二步读取nacos注册中心的配置,第三步读取本地配置文件application.yml,将读取到的配置和nacos配置合并
实际操作:
第一步:1.引入Nacos的配置管理客户端依赖:
<!--nacos配置管理依赖-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
第二步:2,在configservice中的resource目录添加一个bootstrap.yml文件,这个文件是引导文件,优先级高于application.yml:
server: port: 8072spring: application: name: configservice # 服务名称 profiles: active: test #开发环境,这里是test cloud: nacos: server-addr: localhost:8848 # Nacos地 config: file-extension: yaml # 文件后缀名
这里会根据spring.cloud.nacos.server-addr获取nacos地址,再根据
${spring.application.name}-${spring.profiles.active}.${spring.cloud.nacos.config.file-extension}
作为文件id,来读取配置。
本例中,就是去读取userservice-dev.yaml
:
第三步,读取nacos配置 ,我们在configservice中将czxy.message这个属性注入到ConfigController中做测试:
结果显示:正常获取到nacos配置中心的内容
将配置交给Nacos管理的步骤
① 在 Nacos 中添加配置文件 ② 在微服务中引入 nacos 的 config 依赖 ③ 在微服务中添加 bootstrap.yml ,配置 nacos 地址、当前环境、服务名称、文件后缀名。这些决定了程序启动时去 nacos 读取哪个文件
1.4.5 nacos 配置文件加载顺序
-
spring boot、nacos各种配置文件的加载顺序
1.bootstrap.yml #引导文件,由spring cloud提供
2.application.yml #应用程序文件,有spring boot提供
3.application-[profile].yml #应用程序profile文件,有spring boot提供
4.[serviceName].yml #nacos配置
5.[serviceName]-[profile].yml #nacos配置
-
后面加载的文件,将覆盖前面文件的配置内容
-