Spring Cloud Hystrix異常處理方法詳解
這篇文章主要介紹了Spring Cloud Hystrix異常處理方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
在調用服務執(zhí)行HsytrixCommand實現的run()方法拋出異常時,除HystrixBadRequestException之外,其他異常都會認為是Hystrix命令執(zhí)行失敗并觸發(fā)服務降級處理邏輯.
異常處理
當Hystrix命令因為異常(除了HystrixBadRequestException異常)進入服務降級邏輯之后,往往需要對不同的異常做針對處理,那么就要捕獲異常。對于使用@HystrixCommand注解只需要在降級函數中增加Throwable e對象的定義
/** * HystrixBadRequestException: * 與由HystrixCommand拋出的所有其他異常不同,這不會觸發(fā)回退,也不會對失敗度量進行計數,因此不會觸發(fā)斷路器。 * @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(); }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
SpringBoot集成Hadoop對HDFS的文件操作方法
這篇文章主要介紹了SpringBoot集成Hadoop對HDFS的文件操作方法,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-07-07基于hibernate框架在eclipse下的配置方法(必看篇)
下面小編就為大家?guī)硪黄趆ibernate框架在eclipse下的配置方法(必看篇)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09Java調用shell命令涉及管道、重定向時不生效問題及解決
這篇文章主要介紹了Java調用shell命令涉及管道、重定向時不生效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12