您好,登錄后才能下訂單哦!
怎么使用Nacos作為配置中心,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
我們已經學會了,如何利用Nacos實現服務的注冊與發現。同時,也介紹了在Spring Cloud中,我們可以使用的幾種不同編碼風格的服務消費方式。接下來,我們再來學習一下Nacos的另外一個重要能力:配置管理。
Nacos除了實現了服務的注冊發現之外,還將配置中心功能整合在了一起。通過Nacos的配置管理功能,我們可以將整個架構體系內的所有配置都集中在Nacos中存儲。這樣做的好處,在以往的教程中介紹Spring Cloud Config時也有提到,主要有以下幾點:
分離的多環境配置,可以更靈活的管理權限,安全性更高
應用程序的打包更為純粹,以實現一次打包,多處運行的特點
Nacos的配置管理模型與淘寶開源的配置中心Diamond類似,基礎層面都通過DataId
和Group
來定位配置內容,除此之外還增加了很多其他的管理功能。
下面我們通過一個簡單的例子來介紹如何在Nacos中創建配置內容以及如何在Spring Cloud應用中加載Nacos的配置信息。
第一步:進入Nacos的控制頁面,在配置列表功能頁面中,點擊右上角的“+”按鈕,進入“新建配置”頁面,如下圖填寫內容:
其中:
Data ID
:填入alibaba-nacos-config-client.properties
Group
:不修改,使用默認值DEFAULT_GROUP
配置格式
:選擇Properties
配置內容
:應用要加載的配置內容,這里僅作為示例,做簡單配置,比如:didispace.title=spring-cloud-alibaba-learning
第一步:創建一個Spring Boot應用,可以命名為:alibaba-nacos-config-client
。
第二步:編輯pom.xml
,加入必要的依賴配置,比如:
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.5.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Finchley.SR1</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>0.2.2.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <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-config</artifactId> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.2</version> <optional>true</optional> </dependency> </dependencies> |
上述內容主要三部分:
parent
:定義spring boot的版本
dependencyManagement
:spring cloud的版本以及spring cloud alibaba的版本,由于spring cloud alibaba還未納入spring cloud的主版本管理中,所以需要自己加入
dependencies
:當前應用要使用的依賴內容。這里主要新加入了Nacos的配置客戶端模塊:spring-cloud-starter-alibaba-nacos-config
。由于在dependencyManagement
中已經引入了版本,所以這里就不用指定具體版本了。
可以看到,這個例子中并沒有加入nacos的服務發現模塊,所以這兩個內容是完全可以獨立使用的
第三步:創建應用主類,并實現一個HTTP接口:
@SpringBootApplication public class TestApplication { public static void main(String[] args) { SpringApplication.run(TestApplication.class, args); } @Slf4j @RestController @RefreshScope static class TestController { @Value("${didispace.title:}") private String title; @GetMapping("/test") public String hello() { return title; } } } |
內容非常簡單,@SpringBootApplication
定義是個Spring Boot應用;還定義了一個Controller,其中通過@Value
注解,注入了key為didispace.title
的配置(默認為空字符串),這個配置會通過/test
接口返回,后續我們會通過這個接口來驗證Nacos中配置的加載。另外,這里還有一個比較重要的注解@RefreshScope
,主要用來讓這個類下的配置內容支持動態刷新,也就是當我們的應用啟動之后,修改了Nacos中的配置內容之后,這里也會馬上生效。
第四步:創建配置文件bootstrap.properties
,并配置服務名稱和Nacos地址
spring.application.name=alibaba-nacos-config-client server.port=8001 spring.cloud.nacos.config.server-addr=127.0.0.1:8848 |
注意:這里必須使用
bootstrap.properties
。同時,spring.application.name
值必須與上一階段Nacos中創建的配置Data Id匹配(除了.properties或者.yaml后綴)。
第五步:啟動上面創建的應用。
在啟動的時候,我們可以看到類似上面的日志信息,這里會輸出應用程序要從Nacos中獲取配置的dataId和group。如果在啟動之后,發現配置信息沒有獲取到的時候,可以先從這里著手,看看配置加載的目標是否正確。
第六步:驗證配置獲取和驗證動態刷新
用curl或者postman等工具,訪問接口: localhost:8001/test
,一切正常的話,將返回Nacos中配置的spring-cloud-alibaba-learning
。然后,再通過Nacos頁面,修改這個內容,點擊發布之后,再訪問接口,可以看到返回結果變了。
看完上述內容,你們掌握怎么使用Nacos作為配置中心的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。