11.Spring Cloud Alibaba 服務(wù)配置

目錄:Spring Cloud Alibaba 教程
上一篇:10.Spring Cloud Alibaba 網(wǎng)關(guān)全局過濾
下一篇:12.Spring Cloud Alibaba 鏈路追蹤

Nacos Config 服務(wù)端初始化

分布式配置中心


在分布式系統(tǒng)中,由于服務(wù)數(shù)量巨多绒瘦,為了方便服務(wù)配置文件統(tǒng)一管理蝶溶,實時更新哈打,所以需要分布式配置中心組件。

Nacos Config


Nacos 提供用于存儲配置和其他元數(shù)據(jù)的 key/value 存儲驹愚,為分布式系統(tǒng)中的外部化配置提供服務(wù)器端和客戶端支持姻采。使用 Spring Cloud Alibaba Nacos Config近尚,您可以在 Nacos Server 集中管理你 Spring Cloud 應(yīng)用的外部屬性配置。

Spring Cloud Alibaba Nacos Config 是 Spring Cloud Config Server 和 Client 的替代方案鸡岗,客戶端和服務(wù)器上的概念與 Spring Environment 和 PropertySource 有著一致的抽象剖淀,在特殊的 bootstrap 階段,配置被加載到 Spring 環(huán)境中纤房。當(dāng)應(yīng)用程序通過部署管道從開發(fā)到測試再到生產(chǎn)時纵隔,您可以管理這些環(huán)境之間的配置,并確保應(yīng)用程序具有遷移時需要運行的所有內(nèi)容。

創(chuàng)建配置文件


需要在 Nacos Server 中創(chuàng)建配置文件捌刮,我們依然采用 YAML 的方式部署配置文件碰煌,操作流程如下:

  • 瀏覽器打開 http://localhost:8848/nacos ,訪問 Nacos Server
  • 新建配置文件绅作,此處我們以之前創(chuàng)建的 服務(wù)提供者 項目為例

注意:Data ID 的默認(rèn)擴(kuò)展名為 .properties 芦圾,希望使用 YAML 配置,此處必須指明是 .yaml

  • 發(fā)布成功后在 “配置列表” 一欄即可看到剛才創(chuàng)建的配置項

Nacos Config 客戶端的使用

POM


此處我們以之前創(chuàng)建的 服務(wù)提供者 項目為例
pom.xml 中增加 org.springframework.cloud:spring-cloud-starter-alibaba-nacos-config 依賴

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

完整的 pom.xml 如下:

<?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>

    <parent>
        <groupId>com.wsl</groupId>
        <artifactId>hello-spring-cloud-alibaba-dependencies</artifactId>
        <version>1.0.0-SNAPSHOT</version>
        <relativePath>../hello-spring-cloud-alibaba-dependencies/pom.xml</relativePath>
    </parent>

    <artifactId>hello-spring-cloud-alibaba-nacos-provider</artifactId>
    <packaging>jar</packaging>

    <name>hello-spring-cloud-alibaba-nacos-provider</name>

    <dependencies>
        <!-- Spring Boot Begin -->
        <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-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <!-- Spring Boot End -->

        <!-- Spring Cloud Begin -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
        <!-- Spring Cloud End -->
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <mainClass>com.wsl.hello.provider.NacosProviderApplication</mainClass>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

bootstrap.properties


創(chuàng)建名為 bootstrap.properties 的配置文件并刪除之前創(chuàng)建的 application.yml 配置文件俄认,由于已經(jīng)在服務(wù)端配置个少,此處不再贅述

# 這里的應(yīng)用名對應(yīng) Nacos Config 中的 Data ID,實際應(yīng)用名稱以配置中心的配置為準(zhǔn)
spring.application.name=nacos-provider-config
# 指定查找名為 nacos-provider-config.yaml 的配置文件
spring.cloud.nacos.config.file-extension=yaml
# Nacos Server 的地址
spring.cloud.nacos.config.server-addr=127.0.0.1:8848

注意:在之前的 Spring Cloud Netflix 課程中有提到過 Spring Boot 配置文件的加載順序眯杏,依次為 bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml 夜焦,其中 bootstrap.properties 配置為最高優(yōu)先級

啟動應(yīng)用程序


啟動應(yīng)用后我們可以通過日志看到,已經(jīng)成功加載到了配置文件


配置的動態(tài)更新


Nacos Config 也支持配置的動態(tài)更新岂贩,操作流程如下:

  • 修改服務(wù)端配置茫经,增加一個 user.name 的屬性
  • 修改 Controller ,增加一個請求方法萎津,測試配置更新效果
// 注入配置文件上下文
@Autowired
private ConfigurableApplicationContext applicationContext;

// 從上下文中讀取配置
@GetMapping(value = "/hi")
public String sayHi() {
    return "Hello " + applicationContext.getEnvironment().getProperty("user.name");
}
  • 通過瀏覽器訪問該接口卸伞,瀏覽器顯示
Hello wangshilin
  • 修改服務(wù)端配置


此時觀察控制臺日志,你會發(fā)現(xiàn)我們已經(jīng)成功刷新了配置


  • 刷新瀏覽器锉屈,瀏覽器顯示
Hello wangshilin1

注意:你可以使用 spring.cloud.nacos.config.refresh.enabled=false 來關(guān)閉動態(tài)刷新

Nacos Config 多環(huán)境的配置

Spring Boot Profile


我們在做項目開發(fā)的時候荤傲,生產(chǎn)環(huán)境和測試環(huán)境的一些配置可能會不一樣,有時候一些功能也可能會不一樣颈渊,所以我們可能會在上線的時候手工修改這些配置信息遂黍。但是 Spring 中為我們提供了 Profile 這個功能。我們只需要在啟動的時候添加一個虛擬機(jī)參數(shù)儡炼,激活自己環(huán)境所要用的 Profile 就可以了妓湘。

操作起來很簡單,只需要為不同的環(huán)境編寫專門的配置文件乌询,如:application-dev.yml榜贴、application-prod.yml, 啟動項目時只需要增加一個命令參數(shù) --spring.profiles.active=環(huán)境配置 即可妹田,啟動命令如下:

java -jar hello-spring-cloud-alibaba-nacos-provider-1.0.0-SNAPSHOT.jar --spring.profiles.active=prod

Nacos Config Profile


spring-cloud-starter-alibaba-nacos-config 在加載配置的時候唬党,不僅僅加載了以 dataid 為 ${spring.application.name}.${file-extension:properties} 為前綴的基礎(chǔ)配置,還加載了 dataid 為 ${spring.application.name}-${profile}.${file-extension:properties} 的基礎(chǔ)配置鬼佣。在日常開發(fā)中如果遇到多套環(huán)境下的不同配置驶拱,可以通過 Spring 提供的 ${spring.profiles.active} 這個配置項來配置。

此處我們以之前創(chuàng)建的 服務(wù)提供者 項目為例

在 Nacos Server 中增加配置


增加一個名為 nacos-provider-config-prod.yaml 的配置

注意:此時晶衷,我將配置文件中的端口由 8081 -> 8082

在項目中增加配置


增加一個名為 bootstrap-prod.properties 的配置文件蓝纲,內(nèi)容如下:

spring.profiles.active=prod
spring.application.name=nacos-provider-config
spring.cloud.nacos.config.file-extension=yaml
spring.cloud.nacos.config.server-addr=127.0.0.1:8848

主要增加了 spring.profiles.active=prod 配置阴孟,用于指定訪問 Nacos Server 中的 nacos-provider-config-prod.yaml 配置

啟動應(yīng)用程序


此時我們有兩個配置文件,分別為 bootstrap.propertiesbootstrap-prod.properties 税迷,我們需要指定啟動時加載哪一個配置文件永丝,操作流程如下:

  • Run -> Edit Configurations..
  • 設(shè)置需要激活的配置


  • 觀察日志,判斷是否成功加載配置



?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末箭养,一起剝皮案震驚了整個濱河市慕嚷,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌毕泌,老刑警劉巖喝检,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異撼泛,居然都是意外死亡挠说,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門坎弯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來纺涤,“玉大人译暂,你說我怎么就攤上這事抠忘。” “怎么了外永?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵崎脉,是天一觀的道長。 經(jīng)常有香客問我伯顶,道長囚灼,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任祭衩,我火速辦了婚禮灶体,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘掐暮。我一直安慰自己蝎抽,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布路克。 她就那樣靜靜地躺著樟结,像睡著了一般。 火紅的嫁衣襯著肌膚如雪精算。 梳的紋絲不亂的頭發(fā)上瓢宦,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天,我揣著相機(jī)與錄音灰羽,去河邊找鬼驮履。 笑死鱼辙,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的玫镐。 我是一名探鬼主播座每,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼摘悴!你這毒婦竟也來了峭梳?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤蹂喻,失蹤者是張志新(化名)和其女友劉穎葱椭,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體口四,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡孵运,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了蔓彩。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片治笨。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖赤嚼,靈堂內(nèi)的尸體忽然破棺而出旷赖,到底是詐尸還是另有隱情,我是刑警寧澤更卒,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布等孵,位于F島的核電站,受9級特大地震影響蹂空,放射性物質(zhì)發(fā)生泄漏俯萌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一上枕、第九天 我趴在偏房一處隱蔽的房頂上張望咐熙。 院中可真熱鬧,春花似錦辨萍、人聲如沸棋恼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蘸泻。三九已至,卻和暖如春嘲玫,著一層夾襖步出監(jiān)牢的瞬間悦施,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工去团, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留抡诞,地道東北人穷蛹。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像昼汗,于是被迫代替她去往敵國和親肴熏。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內(nèi)容