调用方法[manageapp]时发生异常_探讨通过Feign配合Hystrix进行调用时异常的处理
生活随笔
收集整理的這篇文章主要介紹了
调用方法[manageapp]时发生异常_探讨通过Feign配合Hystrix进行调用时异常的处理
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
原文作者作者:任聰
前言:此文所述處理方式為本人在實(shí)踐過程中研究分析得出的一種解決方案。
本文不僅希望能為 SC 學(xué)習(xí)者提供一種如題問題的一種解決方案,并且希望通過本文引出各位 SC 的朋友對(duì)如題問題的共同探討和最佳實(shí)踐方案的分享。
場(chǎng)景及痛點(diǎn)
- 單個(gè)項(xiàng)目是通過 Jersey 來實(shí)現(xiàn) restful 風(fēng)格的架構(gòu)
- 發(fā)生異常時(shí)異常信息總是提示沒有回調(diào)方法,不能顯示基礎(chǔ)服務(wù)拋出的異常信息
- 暫時(shí)沒有考慮發(fā)生異常之后進(jìn)行回調(diào)返回特定內(nèi)容
- 業(yè)務(wù)系統(tǒng)通過 feign 調(diào)用基礎(chǔ)服務(wù),基礎(chǔ)服務(wù)是會(huì)根據(jù)請(qǐng)求拋出各種請(qǐng)求異常的(采用標(biāo)準(zhǔn)http狀態(tài)碼),現(xiàn)在我的想法是如果調(diào)用基礎(chǔ)服務(wù)時(shí)發(fā)生請(qǐng)求異常,業(yè)務(wù)系統(tǒng)返回的能夠返回基礎(chǔ)服務(wù)拋出的狀態(tài)碼
- 當(dāng)然基礎(chǔ)服務(wù)拋出的請(qǐng)求異常不能觸發(fā) hystrix 的熔斷機(jī)制
問題分析與解決方案
解決思路
- 通過網(wǎng)上一些資料的查詢,看到很多文章會(huì)說 HystrixBadRequestException 不會(huì)觸發(fā) hystrix 的熔斷 --> 但是并沒有介紹該異常的實(shí)踐方案
- 感覺要解決項(xiàng)目的痛點(diǎn),切入點(diǎn)應(yīng)該就在 HystrixBadRequestException 了。于是先看源碼,一方面對(duì) Hystrix 加深理解,嘗試?yán)斫庾髡咴O(shè)計(jì)的初衷與想法,另一方面看看是否能找到其他方案達(dá)到較高的實(shí)踐標(biāo)準(zhǔn)
主要類對(duì)象簡(jiǎn)介
- interface UserRemoteCall 定義feign的接口其上會(huì)有 @FeignClient,FeignClient 定義了自己的 Configuration --> FeignConfiguration
- class FeignConfiguration 這里是定義了指定 Feign 接口使用的自定義配置,如果不想該配置成為全局配置,不要讓該類被自動(dòng)掃描到
- class UserErrorDecoder implements ErrorDecoder 該類會(huì)處理響應(yīng)狀態(tài)碼 (![200,300) || !404)
源碼分析
Feign 的默認(rèn)配置在 org.springframework.cloud.netflix.feign.FeignClientsConfiguration類中,如果不自定義Feign.Builder,會(huì)優(yōu)先配置 feign.hystrix.HystrixFeign.Builder extends Feign.Builder,該類會(huì)讓 Feign 的內(nèi)部調(diào)用受到 Hystrix 的控制
//省略部分代碼@Configuration@ConditionalOnClass({ HystrixCommand.class, HystrixFeign.class })protected static class HystrixFeignConfiguration { @Bean @Scope("prototype") @ConditionalOnMissingBean @ConditionalOnProperty(name = "feign.hystrix.enabled總結(jié)
以上是生活随笔為你收集整理的调用方法[manageapp]时发生异常_探讨通过Feign配合Hystrix进行调用时异常的处理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: go定时读取mysql_golang+数
- 下一篇: sklearn 随机分割数据_sklea