使用Spring Cloud Fegin + Hystrix的failed and fallback failed問(wèn)題解決

背景

服務(wù)使用Spring Cloud Fegin + Hystrix 來(lái)使用RPC調(diào)用
Spring Cloud 版本:2.1.3.RELEASE

報(bào)錯(cuò)信息如下:


AccDingtalkClient#getDingtalkAuthAccessToken(String) failed and fallback failed

這個(gè)日志只能看出失敗并且降級(jí)也失敗了,但是具體怎么失敗了也沒(méi)有說(shuō)明,所以只能本地?cái)帱c(diǎn)看下到底是什么錯(cuò)誤

過(guò)程

我們知道Hystrix最主要的抽象類是HystrixCommand;
Fegin-Hystrix的HystrixInvocationHandler.invoke則是主要用于FeginClient降級(jí)的代碼塊(對(duì)于其他源碼實(shí)現(xiàn)感興趣的人可以去查哈,我這兒只是講調(diào)試看到的主要地方),所以我在這個(gè)代碼塊中打斷點(diǎn)(調(diào)試的時(shí)候還去HystrixCommand打了斷點(diǎn),但是一直沒(méi)有找到真正的原因):


image.png

很容易看出,實(shí)際錯(cuò)誤是沒(méi)有權(quán)限,這是第一個(gè)問(wèn)題,那為什么fallback會(huì)失敗呢,繼續(xù)斷點(diǎn)


image.png

fallbackFactory沒(méi)有值,我看了Client定義是有值的,所以我又重新啟動(dòng)一遍,斷點(diǎn)打在fallbackFactory賦值的地方


image.png

還是為空,看了其他的client,都不是空的,然后再去看FeginClient的定義
image.png

所以是Fallback定義寫(xiě)混了,fallback的方法也沒(méi)有找到,導(dǎo)致failback failed

后記

原因很簡(jiǎn)單,只是想記錄下解決問(wèn)題的方式,也許對(duì)你解決問(wèn)題有幫助

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容