Springboot深入講解nocos的整合與使用
前言
Nacos 致力於幫助您發現、配置和管理微服務。Nacos 提供瞭一組簡單易用的特性集,幫助您快速實現動態服務發現、服務配置、服務元數據及流量管理。
Nacos 幫助您更敏捷和容易地構建、交付和管理微服務平臺。 Nacos 是構建以“服務”為中心的現代應用架構 (例如微服務范式、雲原生范式) 的服務基礎設施
1, 創建工程
先創建maven工程,父工程pom如下:
<?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"> <modelVersion>4.0.0</modelVersion> <groupId>org.example</groupId> <artifactId>configDemo</artifactId> <version>1.0-SNAPSHOT</version> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.2.RELEASE</version> </parent> <dependencies> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>2.2.5.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> </project>
2,啟動nacos-server服務
訪問的url是:http://localhost:8848/nacos/ 默認端口是8848,賬號密碼是:nacos/nocos
3,編寫controller進行動態配置生效
import org.springframework.beans.factory.annotation.Value; import org.springframework.cloud.context.config.annotation.RefreshScope; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; /** * @author yhq * @version 1.0 * @date 2022/7/15 19:07 */ @RestController @RefreshScope //@RefreshScope:需要配置這個才能動態更新配置。 public class TestController { @Value("${name}") private String name; @GetMapping("/getName") public String test(){ return name; } }
4,添加配置文件boostrap.yaml
springboot默認加載配置文件順序:
bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml 其中bootstrap.properties 配置為最高優先級先加載的會被後加載的覆蓋掉,所以.properties和.yml同時存在時,.properties會失效,.yml會起作用。”
#端口
server:
port: 8888
#配置項目名稱
spring:
application:
#configdemo默認是nacos的DateId名稱
name: configdemo
#指定test的配置文件
profiles:
active: test
cloud:
nacos:
config:
server-addr: localhost:8848
#加載yaml的nacos文件
file-extension: yaml
可以看到啟動時進行加載瞭文件如下:
5,nacos配置
配置瞭configdemo和configdemo-test.yaml
註意的是:它的加載規則是:# 1.DataId
– 用來讀取遠程配置中心的中具體配置文件其完整格式如下:
– ${prefix}-${spring.profile.active}.${file-extension}
a. prefix 默認為 spring.application.name 的值,也可以通過配置項 spring.cloud.nacos.config.prefix來配置。
b. spring.profile.active 即為當前環境對應的 profile,詳情可以參考 Spring Boot文檔。 註意:當 spring.profile.active 為空時,對應的連接符 – 也將不存在,dataId 的拼接格式變成 ${prefix}.${file-extension}
c. file-exetension 為配置內容的數據格式,可以通過配置項 spring.cloud.nacos.config.file-extension 來配置。目前隻支持 properties 和 yaml 類型。
如果configdemo和configdemo-test.yaml 都存在name的配置,優先configdemo-test.yaml
訪問結果如下:
以上是針對同個服務不同環境配置應用情況。
到此這篇關於Springboot深入講解nocos的整合與使用的文章就介紹到這瞭,更多相關Springboot nocos內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- spring cloud如何集成nacos配置中心
- springboot使用nacos的示例詳解
- SpringCloud使用Nacos保存和讀取變量的配置方法
- SpringCloud中Gateway的使用教程詳解
- Java微服務Nacos Config配置中心超詳細講解