Nacos作為配置中心–基礎配置
建立cloudalibaba-config-nacos-client3377
依賴:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>cloud2020</artifactId>
<groupId>pers.zhang.springcloud</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>cloudalibaba-config-nacos-client3377</artifactId>
<dependencies>
<!--nacos-config-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<!--nacos-discovery-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--web + actuator-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!--一般基礎配置-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
</project>
配置:
Nacos和SpringCloud-config一樣,在項目初始化時,要保證先從配置中心進行配置拉取,拉取配置成功之後,才能保證項目的正常啟動。
springboot中配置檔案的加載順序是存在優先順序的,
bootstrap優先級高于application。
bootstrap.yml:
server:
port: 3377
spring:
application:
name: nacos-config-client
cloud:
nacos:
discovery:
server-addr: localhost:8848 #Nacos服務注冊中心位址
config:
server-addr: localhost:8848 #Nacos作為配置中心位址
file-extension: yaml #指定格式
# #{spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}
application.yml:
spring:
profiles:
active: dev #指定為開發環境
啟動類:
@EnableDiscoveryClient
@SpringBootApplication
public class NacosConfigClientMain3377 {
public static void main(String[] args) {
SpringApplication.run(NacosConfigClientMain3377.class, args);
}
}
Controller:
@RestController
@RefreshScope //支援Nacos的動态重新整理
public class ConfigClientController {
@Value("${config.info}")
String configInfo;
@GetMapping("/config/info")
public String getConfigInfo() {
return configInfo;
}
}
Nacos中添加配置資訊
官網:
https://nacos.in/zh-cn/docs/quick-start-spring-cloud.html
Nacos中的比對規則:
說明:之是以需要配置 spring.application.name ,是因為它是構成 Nacos 配置管理 dataId字段的一部分。
在 Nacos Spring Cloud 中,dataId 的完整格式如下:
${prefix}-${spring.profile.active}.${file-extension}
-
預設為prefix
的值,也可以通過配置項spring.application.name
來配置。spring.cloud.nacos.config.prefix
-
即為目前環境對應的 profile,詳情可以參考 Spring Boot文檔。 注意:當 -spring.profile.active
為空時,對應的連接配接符spring.profile.active
也将不存在,-
的拼接格式變成dataId
-${prefix}.${file-extension}
為配置内容的資料格式,可以通過配置項file-exetension
來配置。目前隻支援spring.cloud.nacos.config.file-extension
和properties
類型。yaml
最終格式:
{spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}
新增配置:
測試:
啟動3377微服務,通路:
localhost:3377/config/info
,成功擷取配置:
nacos自帶動态重新整理:
修改nacos中的配置檔案為version=2,再次調用接口:
Nacos作為配置中心–分類配置
解決多環境多項目管理問題。
配置管理:
public為預設的保留命名空間。
Namespace+Group+Data ID的關系:
類似Java裡面的package名和類名,最外層的namespace是可以用于區分部署環境的,Group和Data ID邏輯上區分兩個目标對象。
預設情況:
Namespace=public, Group=DEFAULT_GROUP,預設Cluster是DEFAULT
Nacos預設的命名空間是public,Namespace主要用來實作隔離。
比如說現在有三個環境:開發、測試、生産環境,我們就可以建立三個Namespace,不同的Namespace之間是隔離的。
Group預設是DEFAULT_GROUP,Group可以把不同的微服務劃分到同一個分組裡面去。
Service就是微服務;一個Service可以包含多個Cluster(叢集),Nacos預設Cluster是DEFAULT,Cluster是對指定微服務的一個虛拟劃分。比方說為了容災,将Service微服務分别部署在了杭州機房和廣州機房,這時就可以給杭州機房的Service微服務起一個叢集名稱(HZ),給廣州機房的Service微服務起一個叢集名稱(GZ),還可以讓同一個機房的王i服務互相調用,以提升性能。
Instance就是微服務的執行個體。
指定spring.profile.active和配置檔案的Data ID來使不同環境下讀取不同的配置
- 預設空間+預設分組+建立dev和test兩個Data ID
建立dev配置Data ID:
建立test配置Data ID:
此時,通過spring.profile.active屬性就能進行多環境下配置檔案的讀取:
group分組方案:
在config下增加一條group的配置即可。可配置為DEV_GROUP或TEST_GROUP。
namespace方案:
建立dev/test的Namespace:
按照域名配置填寫:
修改bootstrap.yml,添加命名空間:
application.yml: