使用Nacos作为配置中心统一管理配置
1. 引入依赖
<!--配置中心-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
2. 在resource中创建bootstrap.properties
spring.application.name=qbbmall-coupon
spring.cloud.nacos.config.server-addr=ip:8848
3. 在配置中心中添加一个数据集(DataId),默认规则,应用名.properties

4.给应用添加.properties的任意配置

5. 动态获取配置
@RefreshScope // 刷新注解,重新从配置中心获取配置信息
@Value("${配置项的名称}") // 获取配置
注意:如果配置中心和当前的应用都配置了相同的配置项,优先使用配置中心的配置
几个核心概念
1.命名空间:配置隔离
默认:public(保留空间),默认新增的所有配置都在public空间
①开发.测试.生产:每个阶段所用的配置都是不一样的,可以利用命名空间做环境隔离
注意:需要在bootstrap中配置使用哪个命名空间下的配置
spring.cloud.nacos.config.namespace=8a41075e-26c5-4a24-990f-c22bea01c6e5

②每个微服务之间相互隔离配置,每一个微服务都创建自己的命名空间,只加载自己的命名空间下的配置
2.配置集:所有的配置集合
3.配置集的ID:类似配置文件名
DataID:
4.配置分组
默认所有的配置集都属于:DEFAULT_GROUP

想让他生效只需加一段配置即可
spring.cloud.nacos.config.group=qiuqiu
每个微服务都创建自己的命名空间,使用配置分组区分环境,dev,prod,test
同时加载多个配置集
我们开发项目需要配置非常多的配置信息,有mybatis,mysql,springboot...等,这些配置信息我们都是写在同一个配置文件中,其实nacos也支持我们拆分配置信息

spring.application.name=qbbmall-coupon
spring.cloud.nacos.config.server-addr=ip:8848
spring.cloud.nacos.config.namespace=44e7a6fe-b3f2-4916-955f-2761b3fa3af7
spring.cloud.nacos.config.group=prod
spring.cloud.nacos.config.ext-config[0].data-id=datasource.yml
spring.cloud.nacos.config.ext-config[0].group=dev
spring.cloud.nacos.config.ext-config[0].refresh=true
spring.cloud.nacos.config.ext-config[1].data-id=mybatis.yml
spring.cloud.nacos.config.ext-config[1].group=dev
spring.cloud.nacos.config.ext-config[1].refresh=true
spring.cloud.nacos.config.ext-config[2].data-id=other.yml
spring.cloud.nacos.config.ext-config[2].group=dev
spring.cloud.nacos.config.ext-config[2].refresh=true
微服务的任何配置信息,任何配置文件都可以放在配置中心,只需要在bootstrap.properties中说明需要加载哪些配置文件即可!以前任何从配置文件中获取值的方式,依旧都可以用!

浙公网安备 33010602011771号