在使用feign進行遠程方法調用時,若是遠程服務端方法出現異常,客戶端有時須要捕獲,而且把異常信息返回給前端,而若是在開啓熔斷
以後,這個異常會被消化,因此說,若是但願拿到服務端異常,feign.hystrix.enable
須要設置爲false,而當不開熔斷時,咱們也有幾種方法把拿到服務端的異常信息,下面總結一下。前端
這個方法比較直觀,也最好理解,但業務層會有不少try...catch這種代碼,因此不是很推薦。ide
注意:雖然服務端方法返回爲ResponseEntity,但出現4xx,5xx這些異常時,仍是會拋出一個FeignException的異常,而這對於服務來講,向前端拋出的仍是5xx的服務端異常,這不是咱們但願看到的。code
try { ResponseEntity<?> body = productClient.add(name); if (body.getStatusCode().equals(HttpStatus.OK)) { return "test"; } else { return body.getBody().toString(); } } catch (FeignException ex) { return ex.getMessage(); }
咱們比較推薦使用這個方法,註冊一個bean對象,當feign調用出現異常時,會觸發這個方法,而後咱們再統一處理這個異常,向下流繼續拋出加工後的錯誤信息。對象
/** * feign異常攔截器,當從feign拋出異常時走這個對象. */ @Configuration @Slf4j public class FeignClientErrorDecoder implements ErrorDecoder { @Override public Exception decode(String methodKey, Response response) { logger.info("feign client response:", response); String body = null; try { body = Util.toString(response.body().asReader()); } catch (IOException e) { logger.error("feign.IOException", e); } if (response.status() >= 400 && response.status() <= 500) { throw Exceptions.badRequestParams(body); } return errorStatus(methodKey, response); } }
注意,使用這個方式,須要在熔斷器關閉時才起做用,由於它們的執行過程是,先走這個攔截器,再走熔斷的fallback,因此這個異常會被熔斷吞掉,返回狀態爲200,返回值爲你的fallback的默認值。get