正常搭建配置中心,網上教程多,這裡不討論,只記坑也是為了後來者少花時間在這裡,由於是當時研究了好久才寫的文章,所以只能提供問題的原因,當然會給出印證的思路,閑話不多說進入正題! 版本spring boot2.1.6spring boot admin 2.1.6spring cloud GreenWi ...
正常搭建配置中心,網上教程多,這裡不討論,只記坑也是為了後來者少花時間在這裡,由於是
當時研究了好久才寫的文章,所以只能提供問題的原因,當然會給出印證的思路,閑話不多說進入正題!
版本
spring boot2.1.6
spring boot admin 2.1.6
spring cloud GreenWich.SR1
啟動時可以看見配置服務端載入了一些配置文件,如:Adding XXX,啟動客戶端時,發現有fetching XXX,並且使用/actuator/refresh可以刷新客戶端,當然要刷新的配置需要使用@RefreshScope註解標註,實現了以上操作基本上已經搭建成功了.
在不使用spring boot admin(簡稱:SBA)接入服務時,實現動態刷新配置應該問題不大
接下來說重點
1.刷新的配置需要使用@RefreshScope註解
2.使用github或者gitee的Webhooks回調刷新介面時,會出現Json解析異常,這個是因為git里給的那些參數,轉的Json不規範,解決方法是使用一個過濾器或者一個轉發器,將請求體給幹掉就行了
正常搭建後如果出現了下麵兩種情況,就是我掉的坑了,希望下麵的分析對你們有用
第一種情況: config的服務端不接入SBA,config的客戶端接入SBA,訪問/actuator/bus-refresh介面可以通過日誌發現配置的服務端可以接收到更新配置的消息,但是發現配置的客戶端不會更新日誌.
原因:配置客戶端是需要通過配置中心刷新配置事件的監聽去實現配置的刷新,但是SBA的接入破壞了時間的監聽.有興趣的可以通過在DispatchServlet這裡端點跟進下源碼,這裡最終會進入到bus包進行處理,這一步說明配置端是沒有任何問題的.
第二種情況: config的服務端和客戶端都接入SBA,有趣的事情發生了,這時config服務端不會接收到任何消息,甚至可能會出現Method Not Support的異常,當然正常的現象應該是可以正常訪問,會響應一個Json串,這個Json串具體的我忘了,這個響應與我們請求配置文件的信息類似.查看rabbitMQ會發現沒有接收到任何的消息.
原因:因為不知道被誰解析了,所以只能通過DispatchServlet去看看到底是誰搞的,一根進,了不得,這個請求並不是給Bus解析的,而是被當成/{name}/{profile}.[正則表達式]解析的,具體在哪個包下我忘了,沒記錯的話應該是spring cloud config的包下解析的.
總的來說,就是SBA的問題,當時找了很久才看到有一個網站上敢說這個是spring留下的一個Bug,我也不知道是不是,但是我就是遇上了
接下來說說解決方法
1.有實力的可以修改源碼,畢竟知道原因了
2.使用第三方配置中心,如:Apollo,Disconf,還有Nacos,需不需要使用第三方看自己項目的需求
3.使用其他版本,這個慎重吧,因為版本的修改有時會讓你崩潰,當然如果修改版本對你項目影響不大的話,還是建議修改版本,這裡給出自己測過沒問題的版本SpringBoot-Admin2.0.3,SpringCloud.Finchley,所以說建立項目選擇的依賴要慎重,不要使用太新的版本,否則遇到問題找不到比較好的解決方法,就會拖延你項目的進度,但是對於學習來說還是不錯的,有坑的地方,只要你啃下去就會收穫良多。
希望這篇文章對你們有幫助,當然也有可能是我菜,只意識到這裡,如果有其他原因或者是其他解決方法希望可以留言給我,畢竟啃了這麼久,啃錯了也要讓我知道下,不然就亂指導了。