Spring Cloud中怎么利用 Hystrix處理異常,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
異常處理
當Hystrix命令因為異常(除了HystrixBadRequestException異常)進入服務降級邏輯之后,往往需要對不同的異常做針對處理,那么就要捕獲異常。對于使用@HystrixCommand注解只需要在降級函數中增加Throwable e對象的定義
/** * HystrixBadRequestException: * 與由HystrixCommand拋出的所有其他異常不同,這不會觸發回退,也不會對失敗度量進行計數,因此不會觸發斷路器。 * @return */ @HystrixCommand(fallbackMethod="helloBackMethodFirst",ignoreExceptions=HystrixBadRequestException.class) public String helloService() { logger.info("start invoke service"); //URI需要使用虛擬主機名(即服務名稱,而不是主機名) //return restTemplate.getForEntity("http://service-provide/hello", String.class).getBody(); throw new RuntimeException("consumer exception"); } /** * 通用降級函數 * @return */ @HystrixCommand(fallbackMethod="helloBackMethodSecond") public String helloBackMethodFirst(Throwable e){ /* * 一些異常判斷 * if(e instanceof CheckEception){ * } * if(e instanceof IllegalStateException){ * } */ //此處可能是另外一個網絡請求,所以也可能出現錯誤 return "error1:"+e.getMessage(); }
看完上述內容,你們掌握Spring Cloud中怎么利用 Hystrix處理異常的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。