springboot集成Nacos 實現多環境動態配置

nacos 阿里旗下的開源項目,一個更易於構建雲原生應用的動態服務發現、配置管理和服務管理平臺。html

隨着我國科技的進步,愈來愈多的開源技術來自我驕傲的中國,之前要了解某項技術除了查看國內大佬博主的文章就是硬着頭皮去看官方的英文文檔。如今好多了,國內的開源項目官方文檔首先就得有中文版的,可是,這nacos的手冊寫的略顯敷衍🤔。

image.png

最近上線了一個項目,上線以前整理生產環境的配置真是讓人頭大,生怕有遺漏或者填錯的地方,若是在現場配置的有問題,改正後還得重啓服務才能生效,這不,對方把咱們的端口少寫了個數字,某功能出現問題,白天他們又不能重啓,只能等到晚上解決。若是可以使用nacos做爲動態的配置中心,直接改配置不須要重啓就能夠解決了。

本章內容介紹的是spring-boot集成nacos ,不是spring-cloud ,導的包不同使用起來也有點差別。java

nacos服務端

首先下載安裝nacos服務端
啓動方法參考Nacos 快速入門
訪問地址 http://127.0.0.1:8848/nacos ; 初始用戶名和密碼都是nacosmysql

建立命名空間

登錄後左側導航欄選擇命名空間,右上角建立命名空間,分別建立dev 和prod 做爲開發和生產環境的配置,不一樣空間互相隔離。用來區分環境很是合適。
image.pnggit

建立配置文件

左側導航欄>配置管理-配置列表
建立配置文件須要填寫DataIdGroupId,以及配置內容
image.pnggithub

spring-boot集成nacos配置中心

添加nacos配置中心的依賴spring

<dependency>
    <groupId>com.alibaba.boot</groupId>
    <artifactId>nacos-config-spring-boot-starter</artifactId>
    <version>${latest.version}</version>
</dependency>

springboot 版本 2.3.2.RELEASE
nacos-config 版本 0.2.7sql

yml配置nacos服務端地址和命名空間

建立配置文件application-dev.ymlapplication-prod.yml
根據在nacos服務端控制檯建立的兩個命名空間的ID分別填寫到開發環境和生產環境的yml文件裏數據庫

  • application-dev.yml
nacos:
  config:
    namespace: 133c9c90-6d9c-45cd-8067-06f853607940
    server-addr: 127.0.0.1:8848
  • application-prod.yml
nacos:
  config:
    namespace: 72008218-19b0-4960-ab44-a0cbdd8097a0
    server-addr: 127.0.0.1:8848

啓動類配置dataIdgroupId

@NacosPropertySource註解填寫dataIdgroupIdautoRefreshed = true 表示動態刷新的總開關,ture:開啓,默認是false.
讀取多個配置文件就寫多個註解,若是兩個配置文件中有相同的配置,排在上面的註解讀取的配置內容優先級最高。
同一個配置文件能夠被同空間的應用共享。安全

@SpringBootApplication
@NacosPropertySource(dataId = "mashu-demo", autoRefreshed = true, groupId = "USER_GROUP")
@NacosPropertySource(dataId = "dashu-demo", autoRefreshed = true, groupId = "USER_GROUP")

注入配置內容

@NacosValue註解獲取配置內容,autoRefreshed = true 表示開啓動態刷新springboot

@NacosValue(value = "${name}", autoRefreshed = true)
private String name;

不一樣環境的啓動方法

啓動參數根據-Dspring.profiles.active=dev-Dspring.profiles.active=prod切換開發和生產環境
讀取application-dev.yml 仍是 application-prod.yml 依據是"-"後面的單詞,即: dev/prod

至此多環境動態配置完成。

數據持久化

爲了保證數據的安全性,nacos還支持將數據同步到數據庫。
這個須要在nacos服務端配置,在下載的nacos安裝包裏面nacos-server-1.2.1\nacos\conf\nacos-mysql.sql有msyql初始化的sql腳本。
根據實際狀況修改配置文件nacos-server-1.2.1\nacos\conf\application.properties

spring.datasource.platform=mysql
### Count of DB:
db.num=1
### Connect URL of DB:
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456

注意:若是以前沒有作持久化,作了持久化以後會把以前的配置幹掉。😒

java SDK

nacos還支持java客戶端對配置內容的操做和配置變動的監聽。

1.導包:

<dependency>
    <groupId>com.alibaba.nacos</groupId>
    <artifactId>nacos-client</artifactId>
    <version>1.2.0</version>
</dependency>

2.根據ip和命名空間獲取配置文件對象ConfigService

String serverAddr = "127.0.0.1:8848";
    String namespace = "72008218-19b0-4960-ab44-a0cbdd8097a0";
    Properties properties = new Properties();
    properties.put("serverAddr", serverAddr);
    properties.put("namespace", namespace);
    ConfigService configService = NacosFactory.createConfigService(properties);

configService對象有幾個經常使用的方法:

1.getConfig()得到配置內容

String dataId = "dashu-demo";
String groupId = "USER_GROUP";
String content = configService.getConfig(dataId, groupId, 5000);

2.publishConfig()發佈配置

String content = "name: mashu";
configService.publishConfig(dataId, group, content);

3.removeConfig()刪除配置

configService.removeConfig(dataId, group);

4.addListener()添加監聽

Listener listener = new Listener() {
    @Override
    public void receiveConfigInfo(String configInfo) {
        System.out.println("變動後讀取到的配置內容:" + "\r\n" + configInfo);
    }
    @Override
    public Executor getExecutor() {
        return null;
    }
configService.addListener(dataId, groupId, listener);

5.removeListener()刪除監聽

configService.removeListener(dataId, groupId, listener);

以上配置內容的獲取,添加,刪除,監聽都是全量的。

相關文章
相關標籤/搜索