Spring Cloud Alibaba + Nacos Config實現配置動態更新

Spring Cloud Alibaba + Nacos Config實現配置動態更新

本文主要介紹使用Spring Cloud Alibaba + Nacos Config實現動態配置自動變更。

相關依賴

<!-- 暴露web接口 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- nacos dynamic config -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

主要配置

下邊的配置要寫在bootstrap.yml或者bootstrap.properties中:

spring:
  application:
    name: cloud-alibaba-nacos-config
  cloud:
    nacos:
      config:
        # 配置文件類型爲yml/yaml, 也可以設置爲properties
        file-extension: yml 
      # nacos服務地址
      server-addr: localhost:8848

在 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.{prefix}.{file-extension}
  • file-exetension 爲配置內容的數據格式,可以通過配置項 spring.cloud.nacos.config.file-extension 來配置。目前只支持 properties 和 yaml 類型。

即最終默認的格式:
${spring.application.name}-${spring.profile.active}.${file-extension}

編寫接口

對外暴露一個測試接口,使用@RefreshScope註解實現動態配置自動更新。

@RestController
@RefreshScope // 開啓動態刷新
public class ConfigController {

    @Value("${user.name}")
    private String userName;

    @Value("${user.age}")
    private int age;

    @GetMapping
    public String hello(){
        return "Hello, " + userName + ", age is " + age;
    }
}

Nacos配置

啓動Nacos,訪問http://localhost:8848/nacos登錄,新建配置:

Data Id爲:${spring.application.name}-${spring.profile.active}.${file-extension}
則本例中爲:cloud-alibaba-nacos-config.yml,新建如下圖yml配置,併發布。

JuqIfg.png

進行測試

啓動項目

@SpringBootApplication
public class AliNacosConfigApplication {
    public static void main(String[] args) {
        SpringApplication.run(AliNacosConfigApplication.class, args);
    }
}

訪問測試
image.png

修改Naocs中的配置
image.png

再次測試,發現數據已經自動刷新了
image.png

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章