FeignClient服務(wù)器拋出異常客戶(hù)端處理方案
FeignClient服務(wù)器拋出異常客戶(hù)端處理
在使用feign進(jìn)行遠(yuǎn)程方法調(diào)用時(shí),如果遠(yuǎn)程服務(wù)端方法出現(xiàn)異常,客戶(hù)端有時(shí)需要捕獲,并且把異常信息返回給前端,而如果在開(kāi)啟熔斷之后,這個(gè)異常會(huì)被消化,所以說(shuō),如果希望拿到服務(wù)端異常,
feign.hystrix.enable需要設(shè)置為false,而當(dāng)不開(kāi)熔斷時(shí),我們也有幾種方法把拿到服務(wù)端的異常信息,下面總結(jié)一下。
feign異常攔截器
注冊(cè)一個(gè)Bean對(duì)象,當(dāng)feign調(diào)用出現(xiàn)異常的時(shí)候,會(huì)觸發(fā)這個(gè)方法:
import com.test.JsonUtils; import feign.Response; import feign.Util; import feign.codec.ErrorDecoder; import io.test.BadRequestException; import io.test.InternalServerErrorException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.context.annotation.Configuration; import java.io.IOException; import java.util.HashMap; import java.util.Map; import static feign.FeignException.errorStatus; /** * @author 飄逝才子 * @date 2020/11/05 * @description */ @Configuration public class FeignClientErrorDecoder implements ErrorDecoder { private Logger logger = LoggerFactory.getLogger(FeignClientErrorDecoder.class); @Override public Exception decode(String methodKey, Response response) { Map<String, Object> jsonBody = new HashMap<>(); jsonBody.put("message", "Internal server error"); try { String body = Util.toString(response.body().asReader()); jsonBody = JsonUtils.toMap(body); } catch (IOException e) { logger.error("feign.IOException", e); } assert jsonBody != null; if (response.status() >= 400 && response.status() < 500) { throw new BadRequestException(jsonBody.get("message").toString()); } if (response.status() >= 500) { throw new InternalServerErrorException(jsonBody.get("message").toString()); } return errorStatus(methodKey, response); } }
注意,使用這個(gè)方式,需要在熔斷器關(guān)閉時(shí)才起作用,因?yàn)樗鼈兊膱?zhí)行過(guò)程是,先走這個(gè)攔截器,再走熔斷的fallback,所以這個(gè)異常會(huì)被熔斷吞掉,返回狀態(tài)為200,返回值為你的fallback的默認(rèn)值。
FeignClient異常合集Mark
問(wèn)題1
feignClient調(diào)用報(bào)異常cause:Content-Type cannot contain wildcard type ‘*’
是因?yàn)檫h(yuǎn)程調(diào)用的時(shí)候入?yún)⒆R(shí)別不了application/json
解決辦法:在方法上加上類(lèi)型即可consumes = MediaType.APPLICATION_JSON_VALUE
@RequestMapping(value = "/xxx/xxx/xxx/xxx/xxx/xxx/result",method = RequestMethod.GET, consumes = MediaType.APPLICATION_JSON_VALUE)
ResponseResult xxx(TaskParam taskParam);
問(wèn)題2
fallback 與fallbackFactory的使用
fallbackFactory:拋出異??刹榭?,一般看里面拋出的異常日志即可判斷遠(yuǎn)程調(diào)用的問(wèn)題所在。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
shardingJdbc3.x?版本的分頁(yè)bug問(wèn)題解析
這篇文章主要為大家介紹了shardingJdbc3.x?版本的分頁(yè)問(wèn)題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06解決java.net.SocketTimeoutException: Read timed out的問(wèn)題
這篇文章主要介紹了解決java.net.SocketTimeoutException: Read timed out的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06vscode 配置java環(huán)境并調(diào)試運(yùn)行的詳細(xì)過(guò)程
這篇文章主要介紹了vscode 配置java環(huán)境并調(diào)試運(yùn)行的詳細(xì)過(guò)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05- Spring事務(wù)的本質(zhì)就是對(duì)數(shù)據(jù)庫(kù)事務(wù)的支持,沒(méi)有數(shù)據(jù)庫(kù)事務(wù),Spring是無(wú)法提供事務(wù)功能的。Spring只提供統(tǒng)一的事務(wù)管理接口,具體實(shí)現(xiàn)都是由數(shù)據(jù)庫(kù)自己實(shí)現(xiàn)的,Spring會(huì)在事務(wù)開(kāi)始時(shí),根據(jù)當(dāng)前設(shè)置的隔離級(jí)別,調(diào)整數(shù)據(jù)庫(kù)的隔離級(jí)別,由此保持一致2022-07-07
Java開(kāi)發(fā)到底為什么要用 IoC 和 AOP
這篇文章主要介紹了Java開(kāi)發(fā)到底為什么要用 IoC 和 AOP,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下2021-02-02