引入依赖
<!--配置中心-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
创建一个bootstrap.properties
spring.application.name=服务名
spring.cloud.nacos.config.server-addr=Nacos地址
需要给配置中心默认添加数据集(DataId)
默认规则:服务名.properties
在数据集里面添加配置内容
动态获取配置
- @RefreshScope:动态刷新配置
- @Value:动态获取配置
备注:如果配置中心和当前应用的配置文件中都配置了相同的配置,优先会使用配置中心的配置;
相关细节
命名空间
用来做配置隔离,默认为public,新增的所有配置都在public空间下,利用命名空间做环境隔离,需要在boostrap.properties配置上,需要使用哪个命名空间下的配置,namespace要写唯一ID
使用场景
- 不同的开发环境
- 每一个微服务之间互相隔离配置,每一个微服务都创建自己的命名空间,只加载自己的命名空间下的配置;
切换命名空间
spring.cloud.nacos.config.namespace=99911482-db02-4f0c-83b7-be3d92fc40b4
配置集
一组相关或者不相关的配置项的集合成为配置集
配置集ID
类似于配置文件名(Data ID)
配置分组
默认所有的配置集都属于DEFAULT_GROUP
spring.cloud.nacos.config.group=1111
每个微服务创建自己的配置集,使用配置分组区分环境(dev、test、prod),在相同命名空间下通过group区分
Nacos加载多配置集
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=myabtis.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
- 微服务的任何配置信息,任何配置文件都可以放在nacos中;
- 只需要在bootstrap.properties说明加载配置中心中的哪些配置即可;
- @Value.@ConfigurationProperties,以前Springboot中任何方法从配质检中获取值,都能使用,配置中心有的优先使用配置中心中的;