访问Nacos的可视化界面添加一个配置
代码部分
导入pom
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
编写一个Controller
@RestController
@RequestMapping("/config")
@RefreshScope
public class ConfigController {
@Value("${yamlFiles.state}")
private String state;
@RequestMapping("/get")
public String get() {
return String.valueOf(state);
}
}
@RefreshScope:实现配置自动更新,spring cloud原生注解
编写bootstrap.yml
nacos的配置中心的bootstrap的优先级高于application
入门使用
server:
port: 8889
# 官方dataId格式:${prefix}-${spring.profiles.active}.${file-extension}
spring:
application:
# 指定dataId的${prefix}
name: nacosConfigTest
profiles:
# 指定dataId的${spring.profiles.active}
active: dev
cloud:
nacos:
config:
server-addr: 192.168.116.1:8848
# 指定dataId的${file-extension}
file-extension: yaml
官方dataID参数说明说明:
${prefix}-${spring.profiles.active}.${file-extension}
- prefix默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
- spring.profiles.active 即为当前环境对应的 profile,注意:当 spring.profiles.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 p r e f i x . {prefix}. prefix.{file-extension}
- file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 **properties **和 yaml 类型。
获取路径:public命名空间–>nacosConfigTest-dev.yaml的dataId配置文件
未写spring.profiles.active的情况的路径路径: public命名空间–>nacosConfigTest.yaml的dataId配置文件*
编写启动类
@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
public class NacosConfigApplication {
public static void main(String[] args) {
SpringApplication.run(NacosConfigApplication.class,args);
System.out.println("spring cloud start success!");
}
}
运行结果
命名空间 及 组的使用
新建一个命名空间
切换至该命名空间
在该命名空间新建一个配置
修改bootstrap.yml文件
server:
port: 8889
# 官方dataId格式:${prefix}-${spring.profiles.active}.${file-extension}
spring:
application:
# 指定dataId的${prefix}
name: nacosConfigTest
profiles:
# 指定dataId的${spring.profiles.active}
active: dev
cloud:
nacos:
config:
server-addr: 192.168.116.1:8848
# 指定dataId的${file-extension}
file-extension: yaml
# 指定哪一个命名空间(命名空间ID:73ccb6fc-2d6e-4116-9ae4-a7f21bbb0835)
namespace: 73ccb6fc-2d6e-4116-9ae4-a7f21bbb0835
# 指定哪个组
group: DEFAULT_GROUP
获取路径:命名空间ID:73ccb6fc-2d6e-4116-9ae4-a7f21bbb0835命名空间–>DEFAULT_GROUP组–>nacosConfigTest-dev.yaml的dataId配置文件
运行结果
多环境配置
新建一个配置文件
修改Controller
@RestController
@RequestMapping("/config")
@RefreshScope
public class ConfigController {
@Value("${yamlFiles.id}")
private Integer id;
@Value("${yamlFiles.state}")
private String state;
@Value("${yamlFiles.name}")
private String name;
@Value("${yamlFiles.age}")
private Integer age;
@Value("${yamlFiles.sex}")
private Integer sex;
@RequestMapping("/get")
public String get() {
return id + "----" + name + "----" + sex + "----" + age + "----" + state;
}
}
修改Bootstrap.yml文件
server:
port: 8889
# 官方dataId格式:${prefix}-${spring.profiles.active}.${file-extension}
spring:
application:
# 指定dataId的${prefix}
name: nacosConfigTest
profiles:
# 指定dataId的${spring.profiles.active}
active: dev
cloud:
nacos:
config:
server-addr: 192.168.116.1:8848
# 指定dataId的${file-extension}
file-extension: yaml
# 指定哪一个命名空间(命名空间ID:73ccb6fc-2d6e-4116-9ae4-a7f21bbb0835)
namespace: 73ccb6fc-2d6e-4116-9ae4-a7f21bbb0835
# 指定哪个组
group: DEFAULT_GROUP
shared-configs[0]:
data-id: namespacetest.yaml
group: DEFAULT_GROUP
# 这个共享配置是否自动刷新
refresh: true
注:多配置可以依次类推
shared-configs[0]:
data-id: namespacetest.yaml
group: DEFAULT_GROUP
# 这个共享配置是否自动刷新
refresh: true
shared-configs[1]:
data-id: namespacetest.yaml
group: DEFAULT_GROUP
# 这个共享配置是否自动刷新
refresh: true
shared-configs[2]:
data-id: namespacetest.yaml
group: DEFAULT_GROUP
# 这个共享配置是否自动刷新
refresh: true
·······
运行结果
*细节:config 的优先级 > **shared-configs[0]*的优先级
nacosConfigTest-dev.yaml 和 namespacetest.yaml 配置文件会合并
会优先使用 nacosConfigTest-dev.yaml 配置文件
如果 nacosConfigTest-dev.yaml配置文件,没有要获取得配置内容
会使用 namespacetest.yaml 的配置的内容
这就是为什么结果的id是1而不是2,因为使用了nacosConfigTest-dev.yaml的配置内容,
nacosConfigTest-dev.yaml的配置文件没有id,name,age,sex会采用namespacetest.yaml 的配置文件内容