- 添加 pom依赖
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<!-- spring-cloud 版本一定要和spring boot 版本相对应 具体对应关系查看官网https://spring.io/projects/spring-cloud -->
<spring-cloud.version>Hoxton.SR3</spring-cloud.version>
<spring-cloud-alibaba.version>0.9.0.RELEASE</spring-cloud-alibaba.version>
<skipTests>true</skipTests>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<scope>import</scope>
<type>pom</type>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>${spring-cloud-alibaba.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
-
创建不同环境配置的命名空间
Data Id
Data Id的默认值为{spring.profile.active}.{spring.application.name}
spring.cloud.nacos.config.file-extension的默认值为properties
当spring.profiles.active未配置时,则匹配{spring.application.name}.properties时,若还存在{spring.profiles.active}.properties,则默认匹配后者,若不存在,则会自动匹配前者
使用spring.application.name作为Data Id的前缀
Group
Group配置项,并没有固定的规定,可以用作多环境、多模块、多版本之间区分配置
Namespace
使用命名空间来区分不同环境的配置,Nacos控制台对不同的Namespace做了Tab栏分组展示
- 添加配置文件 bootstrap.yml
spring:
application:
name: nacos-config
#指定开发环境
profiles:
active: dev
main:
#当遇到同样名字的时候,是否允许覆盖注册
allow-bean-definition-overriding: true
# 配置服务注册中心
cloud:
nacos:
config:
# 配置中心的地址
server-addr: 127.0.0.1:8848
#默认为Public命名空间,可以省略不写 自定义命名空间使用ID值
namespace: 9c1b431c-dfc0-45e6-8f17-c9bcaac71edc
#指定配置群组 --如果是Public命名空间 则可以省略群组配置
group: DEFAULT_GROUP
#文件名 -- 如果没有配置则默认为 ${spring.appliction.name}
prefix: ${spring.application.name}
# 指定配置中心中配置文件的格式
file-extension: yml
discovery:
#指定注册中心的地址,如果你不需要注册该服务,也可以去掉该项,并删除discovery依赖
server-addr: 127.0.0.1:8848
- 在Nacos 控制台添加配置信息 http://127.0.0.1:8848/nacos/ 切换到不同的Tab下添加对应环境的配置信息
DataId设置:
命名规则:{prefix}-{spring.profiles.active}.${file-extension}
prefix默认为 spring.application.name的值,也可以通过配置项spring.cloud.nacos.config.prefix来配置。
Data ID = {spring.cloud.nacos.config.prefix}.{spring.profiles.active}.{spring.cloud.nacos.config.file-extension} 最终拼接出来的就是:nacos-config-dev.yml
Group = ${spring.cloud.nacos.config.group}
详细对照bootstrap.yml中配置信息来命名
- 代码中运用
第一种:
@RestController
@RequestMapping("nacos")
//启用动态配置刷新
@RefreshScope
public class NacosConfigController {
//获取配置的值
@Value("${company.code}")
private String compayCode;
@RequestMapping("/test")
public Object getZkConfig(HttpRequest request){
return " 编码:" + compayCode;
}
}
我通过Nacos-server的控制台进行配置的修改,客户端服务nacos-config也相应的进行热更新,并不需要重新启动服务。