Spring Cloud Hystrix異常處理方法詳解
這篇文章主要介紹了Spring Cloud Hystrix異常處理方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
在調(diào)用服務(wù)執(zhí)行HsytrixCommand實現(xiàn)的run()方法拋出異常時,除HystrixBadRequestException之外,其他異常都會認為是Hystrix命令執(zhí)行失敗并觸發(fā)服務(wù)降級處理邏輯.
異常處理
當Hystrix命令因為異常(除了HystrixBadRequestException異常)進入服務(wù)降級邏輯之后,往往需要對不同的異常做針對處理,那么就要捕獲異常。對于使用@HystrixCommand注解只需要在降級函數(shù)中增加Throwable e對象的定義
/** * HystrixBadRequestException: * 與由HystrixCommand拋出的所有其他異常不同,這不會觸發(fā)回退,也不會對失敗度量進行計數(shù),因此不會觸發(fā)斷路器。 * @return */ @HystrixCommand(fallbackMethod="helloBackMethodFirst",ignoreExceptions=HystrixBadRequestException.class) public String helloService() { logger.info("start invoke service"); //URI需要使用虛擬主機名(即服務(wù)名稱,而不是主機名) //return restTemplate.getForEntity("http://service-provide/hello", String.class).getBody(); throw new RuntimeException("consumer exception"); } /** * 通用降級函數(shù) * @return */ @HystrixCommand(fallbackMethod="helloBackMethodSecond") public String helloBackMethodFirst(Throwable e){ /* * 一些異常判斷 * if(e instanceof CheckEception){ * } * if(e instanceof IllegalStateException){ * } */ //此處可能是另外一個網(wǎng)絡(luò)請求,所以也可能出現(xiàn)錯誤 return "error1:"+e.getMessage(); }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Spring Cloud Hystrix線程池不足的解決方法
- SpringCloud斷路器Hystrix原理及用法解析
- SpringCloud項目集成Feign、Hystrix過程解析
- SpringCloud之熔斷監(jiān)控Hystrix Dashboard的實現(xiàn)
- SpringCloud之熔斷器Hystrix的實現(xiàn)
- SpringCloud Hystrix-Dashboard儀表盤的實現(xiàn)
- SpringCloud微服務(wù)之Hystrix組件實現(xiàn)服務(wù)熔斷的方法
- Spring Cloud 的 Hystrix.功能及實踐詳解
- Springcloud hystrix服務(wù)熔斷和dashboard如何實現(xiàn)
相關(guān)文章
SpringBoot集成Hadoop對HDFS的文件操作方法
這篇文章主要介紹了SpringBoot集成Hadoop對HDFS的文件操作方法,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-07-07基于hibernate框架在eclipse下的配置方法(必看篇)
下面小編就為大家?guī)硪黄趆ibernate框架在eclipse下的配置方法(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09Java調(diào)用shell命令涉及管道、重定向時不生效問題及解決
這篇文章主要介紹了Java調(diào)用shell命令涉及管道、重定向時不生效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12