摘要:添加應(yīng)用啟動(dòng)類(lèi)通過(guò)半自動(dòng)刷新配置。配置客戶(hù)端服務(wù)想要實(shí)現(xiàn)自動(dòng)刷新配置的話(huà),一端是不要做任何處理,只需要在一端處理即可。
SpringCloud(第 037 篇)通過(guò)bus/refresh半自動(dòng)刷新ConfigClient配置
-
一、大致介紹1、上章節(jié)我們講到了手動(dòng)刷新配置,但是我們假設(shè)如果微服務(wù)一多的話(huà),那么我們是不是需要對(duì)每臺(tái)服務(wù)進(jìn)行手動(dòng)刷新呢? 2、答案肯定是不需要的,我們也可以采用 rabbitmq 消息中間件產(chǎn)品來(lái)增強(qiáng)刷新機(jī)制; 3、這里還順便列舉下配置路徑的規(guī)則: /**************************************************************************************** * 配置服務(wù)的路勁規(guī)則: * * /{application}/{profile}[/{label}] * /{application}-{profile}.yml * /{label}/{application}-{profile}.yml * /{application}-{profile}.properties * /{label}/{application}-{profile}.properties ****************************************************************************************/二、實(shí)現(xiàn)步驟 2.1 添加 maven 引用包
2.2 添加應(yīng)用配置文件(springms-config-client-refresh-bus/src/main/resources/application.yml)4.0.0 springms-config-client-refresh-bus 1.0-SNAPSHOT jar com.springms.cloud springms-spring-cloud 1.0-SNAPSHOT org.springframework.cloud spring-cloud-starter-config org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-actuator org.springframework.cloud spring-cloud-starter-bus-amqp
server: port: 8300 ##################################################################################################### # 配置服務(wù)客戶(hù)端Client應(yīng)用入口(正常測(cè)試 ConfigClient ) # profile: profile-dev ##################################################################################################### ##################################################################################################### # 配置服務(wù)客戶(hù)端Client應(yīng)用入口(鏈接 ClientServer 測(cè)試,同時(shí)本地也有一份配置文件,那么該如何抉擇呢?) # profile: profile-local-dev #####################################################################################################2.3 添加 bootstrap.yml 應(yīng)用配置文件(springms-config-client-refresh-bus/src/main/resources/bootstrap.yml)
##################################################################################################### # 配置服務(wù)客戶(hù)端Client應(yīng)用入口(鏈接 ClientServer 測(cè)試) spring: cloud: config: uri: http://localhost:8220 profile: refreshbus label: master #當(dāng) ConfigServer 的后端存儲(chǔ)的是 Git 的時(shí)候,默認(rèn)就是 master bus: trace: enabled: true # 設(shè)置節(jié)點(diǎn)狀態(tài)跟蹤,也可以通過(guò)網(wǎng)頁(yè) http://localhost:8300/trace 可以看到相關(guān)發(fā)送事件的數(shù)據(jù)內(nèi)容 application: name: foobar #取 foobar-refreshbus.yml 這個(gè)文件的 application 名字,即為 foobar 名稱(chēng) ##################################################################################################### ##################################################################################################### # rabbitmq 配置: rabbitmq: host: localhost # 登錄 Rabbitmq 后臺(tái)管理頁(yè)面地址為:http://localhost:15672 port: 5672 username: guest # 默認(rèn)賬戶(hù) password: guest # 默認(rèn)密碼 #####################################################################################################2.4 添加Web控制層類(lèi)(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; /** * 配置客戶(hù)端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 添加應(yīng)用啟動(dòng)類(lèi)(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; /** * 通過(guò)bus/refresh半自動(dòng)刷新ConfigClient配置。三、測(cè)試
* * ConfigClient 配置客戶(hù)端服務(wù)想要實(shí)現(xiàn)自動(dòng)刷新配置的話(huà),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微服務(wù) 】】】】】】已啟動(dòng)."); } }
/**************************************************************************************** application.yml 涉及到的鏈接文件內(nèi)容展示如下: 修改內(nèi)容前: http://git.oschina.net/ylimhhmily/OpenSource_CustomCircleLineProgressBar/blob/master/foobar-refreshbus.yml profile: profile-refreshbus 修改內(nèi)容后: http://git.oschina.net/ylimhhmily/OpenSource_CustomCircleLineProgressBar/blob/master/foobar-refreshbus.yml profile: profile-refreshbus-refresh ****************************************************************************************/ /**************************************************************************************** Rabbitmq 安裝步驟(進(jìn)入 Rabbitmq 官網(wǎng):http://www.rabbitmq.com): 1、下載 rabbitmq-server-3.6.11.exe、otp_win64_20.0-rc2.exe 兩個(gè) windows 安裝軟件; 2、雙擊安裝 otp_win64_20.0-rc2.exe; 3、雙擊安裝 rabbitmq-server-3.6.11.exe; 4、兩個(gè)都安裝完后會(huì)發(fā)現(xiàn)服務(wù)中多了一個(gè) Rabbitmq 的服務(wù),服務(wù)名稱(chēng)為:RabbitMQ; 5、如果想查看管理界面的話(huà),執(zhí)行命令:rabbitmq-plugins enable rabbitmq_management,然后重啟 RabbitMQ 服務(wù); 6、通過(guò)windows命令 netstat -aon|findstr "5672" 查看該端口是否被占用,占用的話(huà),說(shuō)明安裝基本上一切正常; 7、通過(guò) http://localhost:15672 地址可以進(jìn)入服務(wù)端的管理頁(yè)面; 總結(jié):到此為止,Rabbitmq 已經(jīng)安裝完成,接下來(lái)準(zhǔn)備接入 SpringCloud 生態(tài)圈。 ****************************************************************************************/ /**************************************************************************************** 一、配置刷新服務(wù)客戶(hù)端Client應(yīng)用入口(通過(guò) bus/refresh 實(shí)現(xiàn)半自動(dòng)動(dòng)態(tài)刷新配置服務(wù)客戶(hù)端配置): 1、添加注解 RefreshScope,然后添加引用模塊 spring-boot-starter-actuator 監(jiān)控和管理生產(chǎn)環(huán)境的模塊; 2、編輯 application.yml、bootstrap.yml 文件,添加相關(guān)客戶(hù)端配置; 3、啟動(dòng) springms-config-server 模塊服務(wù),啟動(dòng)1個(gè)端口; 4、啟動(dòng) springms-config-client-refresh-bus 模塊服務(wù),啟動(dòng)3個(gè)端口(8300、8301、8302); 5、在瀏覽器輸入地址 http://localhost:8300/profile 正常情況下會(huì)輸出遠(yuǎn)端服務(wù)的配置內(nèi)容(內(nèi)容為:profile: profile-refreshbus); 6、在瀏覽器輸入地址 http://localhost:8301/profile 正常情況下會(huì)輸出遠(yuǎn)端服務(wù)的配置內(nèi)容(內(nèi)容為:profile: profile-refreshbus); 7、在瀏覽器輸入地址 http://localhost:8302/profile 正常情況下會(huì)輸出遠(yuǎn)端服務(wù)的配置內(nèi)容(內(nèi)容為:profile: profile-refreshbus); 8、修改 http://git.oschina.net/ylimhhmily/OpenSource_CustomCircleLineProgressBar/blob/master/foobar-refreshbus.yml 內(nèi)容,修改后為 profile: profile-refreshbus-refresh; 9、打開(kāi)windows命令窗口,執(zhí)行命令: >curl.exe -X POST http://localhost:8300/bus/refresh 或者端口選擇 8301、8302 都可以生效; 10、然后刷新 http://localhost:8300/profile 網(wǎng)頁(yè),正常情況下會(huì)輸出遠(yuǎn)端服務(wù)的配置內(nèi)容(內(nèi)容為:profile: profile-refreshbus-refresh); 11、然后刷新 http://localhost:8301/profile 網(wǎng)頁(yè),正常情況下會(huì)輸出遠(yuǎn)端服務(wù)的配置內(nèi)容(內(nèi)容為:profile: profile-refreshbus-refresh); 12、然后刷新 http://localhost:8302/profile 網(wǎng)頁(yè),正常情況下會(huì)輸出遠(yuǎn)端服務(wù)的配置內(nèi)容(內(nèi)容為:profile: profile-refreshbus-refresh); 總結(jié):這里通過(guò)執(zhí)行刷新命令,然后將多臺(tái) ConfigClient 客戶(hù)端刷新,來(lái)達(dá)到獲取最新的遠(yuǎn)端服務(wù)器配置。 但是這里終究還是得靠手動(dòng)執(zhí)行一條刷新命令,但總比每臺(tái)服務(wù)器執(zhí)行刷新命令要好很多; ****************************************************************************************/ /**************************************************************************************** 二、配置刷新服務(wù)客戶(hù)端Client應(yīng)用入口(設(shè)置 Git 的 WebHooks 屬性,通過(guò) Git 提交代碼來(lái)實(shí)現(xiàn)全自動(dòng)動(dòng)態(tài)刷新配置服務(wù)客戶(hù)端配置): 總結(jié):這里我就不做過(guò)多的測(cè)試,WebHooks 可以設(shè)置 POST 的地址,并附上密碼,提交代碼后動(dòng)態(tài)通知相應(yīng)服務(wù)來(lái)實(shí)現(xiàn)全自動(dòng)動(dòng)態(tài)刷新。 ****************************************************************************************/ /**************************************************************************************** 三、思考問(wèn)題:憑什么 8300、8301、8302 三臺(tái)服務(wù)器其中一臺(tái)要承受刷新配置服務(wù)的任務(wù)?不應(yīng)該三臺(tái)服務(wù)的角色等級(jí)應(yīng)該相同么? 基于這種角色等同考慮,可以在 ConfigServer 也配上 Rabbitmq 鏈接上,然后我們?cè)谟妹钏⑿?ConfigServer 即可,這樣就實(shí)現(xiàn)了三臺(tái) ConfigClient 服務(wù)器的角色又等同了; ****************************************************************************************/四、下載地址
https://gitee.com/ylimhhmily/SpringCloudTutorial.git
SpringCloudTutorial交流QQ群: 235322432
SpringCloudTutorial交流微信群: 微信溝通群二維碼圖片鏈接
歡迎關(guān)注,您的肯定是對(duì)我最大的支持!!!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/67804.html
摘要:添加應(yīng)用啟動(dòng)類(lèi)單點(diǎn)手動(dòng)動(dòng)態(tài)刷新配置。配置客戶(hù)端服務(wù)想要實(shí)現(xiàn)自動(dòng)刷新配置的話(huà),一端是不要做任何處理,只需要在一端處理即可。 SpringCloud(第 036 篇)單點(diǎn)手動(dòng)動(dòng)態(tài)刷新ConfigClient配置 - 一、大致介紹 1、當(dāng)ConfigServer啟動(dòng)后,假如我們新增配置內(nèi)容的話(huà),是不是要重新啟動(dòng)一下ConfigServer呢? 2、答案肯定是不需要重新啟動(dòng)的,因?yàn)?Sprin...
SpringCloud(第 029 篇)配置客戶(hù)端 ConfigClient 接入配置服務(wù)端 - 一、大致介紹 1、有配置服務(wù)端,那么勢(shì)必就會(huì)有與之對(duì)應(yīng)的客戶(hù)端,SpringCloud 文檔中集成也非常簡(jiǎn)單; 2、但是這里有點(diǎn)需要注意,就是 bootstrap 配置文件,官方建議我們?cè)赽ootstrap中放置不更改的屬性,我們同樣也需要在這里做一些簡(jiǎn)單不易于改變的配置; 3、這里還順便列舉下配置...
SpringCloud(第 035 篇)配置服務(wù)客戶(hù)端ConfigClient鏈接經(jīng)過(guò)認(rèn)證的配置服務(wù)端 - 一、大致介紹 1、前面一章節(jié)講解了服務(wù)端配置安全認(rèn)證,那么本章節(jié)就講解如何鏈接上服務(wù)端的認(rèn)證; 2、這里還順便列舉下配置路徑的規(guī)則: /*****************************************************************************...
摘要:添加應(yīng)用啟動(dòng)類(lèi)配置客戶(hù)端鏈接經(jīng)過(guò)對(duì)稱(chēng)加解密的配置微服務(wù)專(zhuān)門(mén)為測(cè)試經(jīng)過(guò)對(duì)稱(chēng)加解密的配置微服務(wù)微服務(wù)模塊。 SpringCloud(第 031 篇)配置客戶(hù)端ConfigClient鏈接經(jīng)過(guò)對(duì)稱(chēng)加解密的配置微服務(wù) - 一、大致介紹 1、Git服務(wù)端的文件內(nèi)容進(jìn)行了加密處理,那么是不是配置客戶(hù)端拿到內(nèi)容之后需要解密呢? 2、答案顯然不是的,因?yàn)檫@樣解密的話(huà),先不說(shuō)實(shí)現(xiàn)起來(lái)的難易程度,單從表面...
SpringCloud(第 033 篇)配置客戶(hù)端ConfigClient鏈接經(jīng)過(guò)對(duì)稱(chēng)加解密的配置微服務(wù) - 一、大致介紹 1、在(第 031 篇)講解了如何鏈接對(duì)稱(chēng)加密的配置服務(wù)端,而鏈接對(duì)稱(chēng)非對(duì)稱(chēng)加密的配置微服務(wù)也是同樣的; 2、配置客戶(hù)端不需要做什么加解密的配置,加解密的配置在服務(wù)端做就好了; 3、這里還順便列舉下配置路徑的規(guī)則: /****************************...
閱讀 725·2021-11-15 11:39
閱讀 2969·2021-10-08 10:04
閱讀 3353·2019-08-30 10:57
閱讀 3075·2019-08-26 13:25
閱讀 1964·2019-08-26 12:14
閱讀 2706·2019-08-23 15:27
閱讀 3067·2019-08-23 15:18
閱讀 1835·2019-08-23 14:26