SpringCloud(第 037 篇)通過bus/refresh半自動刷新ConfigClient配置

SpringCloud(第 037 篇)通過bus/refresh半自動刷新ConfigClient配置

一、大致介紹

1、上章節我們講到了手動刷新配置,但是我們假設如果微服務一多的話,那么我們是不是需要對每臺服務進行手動刷新呢?
2、答案肯定是不需要的,我們也可以采用 rabbitmq 消息中間件產品來增強刷新機制;

3、這里還順便列舉下配置路徑的規則:
/****************************************************************************************
 * 配置服務的路勁規則:
 *
 * /{application}/{profile}[/{label}]
 * /{application}-{profile}.yml
 * /{label}/{application}-{profile}.yml
 * /{application}-{profile}.properties
 * /{label}/{application}-{profile}.properties
 ****************************************************************************************/

二、實現步驟

2.1 添加 maven 引用包

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

    <artifactId>springms-config-client-refresh-bus</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>

    <parent>
        <groupId>com.springms.cloud</groupId>
        <artifactId>springms-spring-cloud</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>

    <dependencies>
        <!-- 客戶端配置模塊 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-config</artifactId>
        </dependency>
        <!-- web模塊 -->
        <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>

        <!-- Rabbitmq模塊 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bus-amqp</artifactId>
        </dependency>

    </dependencies>

</project>

2.2 添加應用配置文件(springms-config-client-refresh-bus/src/main/resources/application.yml)

server:
  port: 8300


#####################################################################################################
# 配置服務客戶端Client應用入口(正常測試 ConfigClient )
# profile: profile-dev
#####################################################################################################





#####################################################################################################
# 配置服務客戶端Client應用入口(鏈接 ClientServer 測試,同時本地也有一份配置文件,那么該如何抉擇呢?)
# profile: profile-local-dev
#####################################################################################################

2.3 添加 bootstrap.yml 應用配置文件(springms-config-client-refresh-bus/src/main/resources/bootstrap.yml)


#####################################################################################################
# 配置服務客戶端Client應用入口(鏈接 ClientServer 測試)
spring:
  cloud:
    config:
      uri: http://localhost:8220
      profile: refreshbus
      label: master #當 ConfigServer 的后端存儲的是 Git 的時候,默認就是 master

    bus:
      trace:
        enabled: true   # 設置節點狀態跟蹤,也可以通過網頁 http://localhost:8300/trace 可以看到相關發送事件的數據內容

  application:
    name: foobar  #取 foobar-refreshbus.yml 這個文件的 application 名字,即為 foobar 名稱
#####################################################################################################

#####################################################################################################
# rabbitmq 配置:
  rabbitmq:
    host: localhost   # 登錄 Rabbitmq 后臺管理頁面地址為:http://localhost:15672
    port: 5672
    username: guest   # 默認賬戶
    password: guest   # 默認密碼
#####################################################################################################

2.4 添加Web控制層類(springms-config-client-refresh-bus/src/main/java/com/springms/cloud/controller/ConfigClientRefreshBusController.java)

package com.springms.cloud.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;

/**
 * 配置客戶端Controller。
 *
 * @author hmilyylimh
 *
 * @version 0.0.1
 *
 * @date 17/10/18
 *
 */
@RestController
@RefreshScope
public class ConfigClientRefreshBusController {

    @Value("${profile}")
    private String profile;

    @GetMapping("/profile")
    public String getProfile(){
        return this.profile;
    }
}

2.5 添加應用啟動類(springms-config-client-refresh-bus/src/main/java/com/springms/cloud/MsConfigClientRefreshBusApplication.java)

package com.springms.cloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * 通過bus/refresh半自動刷新ConfigClient配置。<br/>
 *
 * ConfigClient 配置客戶端服務想要實現自動刷新配置的話,ConfigServer 一端是不要做任何處理,只需要在 ConfigClient 一端處理即可。
 *
 * @author hmilyylimh
 *
 * @version 0.0.1
 *
 * @date 17/10/18
 *
 */
@SpringBootApplication
public class MsConfigClientRefreshBusApplication {

    public static void main(String[] args) {
        SpringApplication.run(MsConfigClientRefreshBusApplication.class, args);
        System.out.println("【【【【【【 ConfigClientRefreshBus微服務 】】】】】】已啟動.");
    }
}

三、測試

/****************************************************************************************
 application.yml 涉及到的鏈接文件內容展示如下:

 修改內容前:
 http://git.oschina.net/ylimhhmily/OpenSource_CustomCircleLineProgressBar/blob/master/foobar-refreshbus.yml
 profile: profile-refreshbus

 修改內容后:
 http://git.oschina.net/ylimhhmily/OpenSource_CustomCircleLineProgressBar/blob/master/foobar-refreshbus.yml
 profile: profile-refreshbus-refresh
 ****************************************************************************************/





/****************************************************************************************
 Rabbitmq 安裝步驟(進入 Rabbitmq 官網:http://www.rabbitmq.com):

 1、下載 rabbitmq-server-3.6.11.exe、otp_win64_20.0-rc2.exe 兩個 windows 安裝軟件;
 2、雙擊安裝 otp_win64_20.0-rc2.exe;
 3、雙擊安裝 rabbitmq-server-3.6.11.exe;
 4、兩個都安裝完后會發現服務中多了一個 Rabbitmq 的服務,服務名稱為:RabbitMQ;
 5、如果想查看管理界面的話,執行命令:rabbitmq-plugins enable rabbitmq_management,然后重啟 RabbitMQ 服務;
 6、通過windows命令 netstat -aon|findstr "5672" 查看該端口是否被占用,占用的話,說明安裝基本上一切正常;
 7、通過 http://localhost:15672 地址可以進入服務端的管理頁面;

 總結:到此為止,Rabbitmq 已經安裝完成,接下來準備接入 SpringCloud 生態圈。
 ****************************************************************************************/






/****************************************************************************************
 一、配置刷新服務客戶端Client應用入口(通過 bus/refresh 實現半自動動態刷新配置服務客戶端配置):

 1、添加注解 RefreshScope,然后添加引用模塊 spring-boot-starter-actuator 監控和管理生產環境的模塊;
 2、編輯 application.yml、bootstrap.yml 文件,添加相關客戶端配置;
 3、啟動 springms-config-server 模塊服務,啟動1個端口;
 4、啟動 springms-config-client-refresh-bus 模塊服務,啟動3個端口(8300、8301、8302);
 5、在瀏覽器輸入地址 http://localhost:8300/profile 正常情況下會輸出遠端服務的配置內容(內容為:profile: profile-refreshbus);
 6、在瀏覽器輸入地址 http://localhost:8301/profile 正常情況下會輸出遠端服務的配置內容(內容為:profile: profile-refreshbus);
 7、在瀏覽器輸入地址 http://localhost:8302/profile 正常情況下會輸出遠端服務的配置內容(內容為:profile: profile-refreshbus);

 8、修改 http://git.oschina.net/ylimhhmily/OpenSource_CustomCircleLineProgressBar/blob/master/foobar-refreshbus.yml 內容,修改后為 profile: profile-refreshbus-refresh;
 9、打開windows命令窗口,執行命令: >curl.exe -X POST http://localhost:8300/bus/refresh 或者端口選擇 8301、8302 都可以生效;

 10、然后刷新 http://localhost:8300/profile 網頁,正常情況下會輸出遠端服務的配置內容(內容為:profile: profile-refreshbus-refresh);
 11、然后刷新 http://localhost:8301/profile 網頁,正常情況下會輸出遠端服務的配置內容(內容為:profile: profile-refreshbus-refresh);
 12、然后刷新 http://localhost:8302/profile 網頁,正常情況下會輸出遠端服務的配置內容(內容為:profile: profile-refreshbus-refresh);

 總結:這里通過執行刷新命令,然后將多臺 ConfigClient 客戶端刷新,來達到獲取最新的遠端服務器配置。
      但是這里終究還是得靠手動執行一條刷新命令,但總比每臺服務器執行刷新命令要好很多;
 ****************************************************************************************/

/****************************************************************************************
 二、配置刷新服務客戶端Client應用入口(設置 Git 的 WebHooks 屬性,通過 Git 提交代碼來實現全自動動態刷新配置服務客戶端配置):

 總結:這里我就不做過多的測試,WebHooks 可以設置 POST 的地址,并附上密碼,提交代碼后動態通知相應服務來實現全自動動態刷新。
 ****************************************************************************************/

/****************************************************************************************
 三、思考問題:憑什么 8300、8301、8302 三臺服務器其中一臺要承受刷新配置服務的任務?不應該三臺服務的角色等級應該相同么?

 基于這種角色等同考慮,可以在 ConfigServer 也配上 Rabbitmq 鏈接上,然后我們在用命令刷新 ConfigServer 即可,這樣就實現了三臺 ConfigClient 服務器的角色又等同了;
 ****************************************************************************************/

四、下載地址

https://gitee.com/ylimhhmily/SpringCloudTutorial.git

SpringCloudTutorial交流QQ群: 235322432

SpringCloudTutorial交流微信群: 微信溝通群二維碼圖片鏈接

歡迎關注,您的肯定是對我最大的支持!!!

<上一篇????????首頁????????下一篇>

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,739評論 6 534
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,634評論 3 419
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,653評論 0 377
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,063評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,835評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,235評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,315評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,459評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,000評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,819評論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,004評論 1 370
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,560評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,257評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,676評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,937評論 1 288
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,717評論 3 393
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,003評論 2 374

推薦閱讀更多精彩內容