背景
服務(wù)使用Spring Cloud Fegin + Hystrix 來使用RPC調(diào)用
Spring Cloud 版本:2.1.3.RELEASE
報錯信息如下:

AccDingtalkClient#getDingtalkAuthAccessToken(String) failed and fallback failed
這個日志只能看出失敗并且降級也失敗了,但是具體怎么失敗了也沒有說明,所以只能本地斷點看下到底是什么錯誤
過程
我們知道Hystrix最主要的抽象類是HystrixCommand;
Fegin-Hystrix的HystrixInvocationHandler.invoke則是主要用于FeginClient降級的代碼塊(對于其他源碼實現(xiàn)感興趣的人可以去查哈,我這兒只是講調(diào)試看到的主要地方),所以我在這個代碼塊中打斷點(調(diào)試的時候還去HystrixCommand打了斷點,但是一直沒有找到真正的原因):

image.png
很容易看出,實際錯誤是沒有權(quán)限,這是第一個問題,那為什么fallback會失敗呢,繼續(xù)斷點

image.png
fallbackFactory沒有值,我看了Client定義是有值的,所以我又重新啟動一遍,斷點打在fallbackFactory賦值的地方

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

image.png
所以是Fallback定義寫混了,fallback的方法也沒有找到,導(dǎo)致failback failed
后記
原因很簡單,只是想記錄下解決問題的方式,也許對你解決問題有幫助