天天看點

SpringCloudAlibaba--Nacos作為服務配置中心

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

    來配置。
  • spring.profile.active

    即為目前環境對應的 profile,詳情可以參考 Spring Boot文檔。 注意:當 -

    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}

新增配置:

SpringCloudAlibaba--Nacos作為服務配置中心

測試:

啟動3377微服務,通路:

localhost:3377/config/info

,成功擷取配置:

SpringCloudAlibaba--Nacos作為服務配置中心

nacos自帶動态重新整理:

修改nacos中的配置檔案為version=2,再次調用接口:

SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心

Nacos作為配置中心–分類配置

解決多環境多項目管理問題。

配置管理:

SpringCloudAlibaba--Nacos作為服務配置中心

public為預設的保留命名空間。

Namespace+Group+Data ID的關系:

類似Java裡面的package名和類名,最外層的namespace是可以用于區分部署環境的,Group和Data ID邏輯上區分兩個目标對象。

SpringCloudAlibaba--Nacos作為服務配置中心

預設情況:

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:

SpringCloudAlibaba--Nacos作為服務配置中心

建立test配置Data ID:

SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心

此時,通過spring.profile.active屬性就能進行多環境下配置檔案的讀取:

SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心

group分組方案:

SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心

在config下增加一條group的配置即可。可配置為DEV_GROUP或TEST_GROUP。

SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心

namespace方案:

建立dev/test的Namespace:

SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心

按照域名配置填寫:

SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心

修改bootstrap.yml,添加命名空間:

SpringCloudAlibaba--Nacos作為服務配置中心

application.yml:

SpringCloudAlibaba--Nacos作為服務配置中心
SpringCloudAlibaba--Nacos作為服務配置中心

繼續閱讀