詳解Spring Cloud Feign 熔斷配置的一些小坑
1.在使用feign做服務(wù)調(diào)用時(shí),使用繼承的方式調(diào)用服務(wù),加入Hystrix的熔斷處理fallback配置時(shí),會(huì)報(bào)錯(cuò),已解決。 2.使用feign默認(rèn)配置,熔斷不生效,已解決。
最近在做微服務(wù)的學(xué)習(xí),發(fā)現(xiàn)在使用feign做服務(wù)調(diào)用時(shí),使用繼承的方式調(diào)用服務(wù),加入Hystrix的熔斷處理fallback配置時(shí),會(huì)報(bào)錯(cuò),代碼如下:
@RequestMapping("/demo/api")
public interface HelloApi {
@GetMapping("user/{id}")
User getUserById(@PathVariable("id") long id);
@GetMapping("hello")
String echo(@RequestParam("name") String name);
}
@FeignClient(value = "ms-server", fallback = ConsumerFeignServiceFallBack.class)
public interface ConsumerFeignService extends HelloApi {
}
@Component
public class ConsumerFeignServiceFallBack implements ConsumerFeignService {
@Override
public User getUserById(long id) {
return new User();
}
@Override
public String echo(String name) {
return "echo error: " + name;
}
}
報(bào)錯(cuò)如下:
Caused by: java.lang.IllegalStateException: Ambiguous mapping. Cannot map 'com.thoughtworks.demo.consumer.service.ConsumerFeignService' method
public abstract java.lang.String com.thoughtworks.demo.api.HelloApi.echo(java.lang.String)
to {[/demo/api/hello],methods=[GET]}: There is already 'consumerFeignServiceFallBack' bean method
public java.lang.String com.thoughtworks.demo.consumer.service.ConsumerFeignServiceFallBack.echo(java.lang.String) mapped.
at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping$MappingRegistry.assertUniqueMethodMapping(AbstractHandlerMethodMapping.java:576) ~[spring-webmvc-4.3.14.RELEASE.jar:4.3.14.RELEASE]
at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping$MappingRegistry.register(AbstractHandlerMethodMapping.java:540) ~[spring-webmvc-4.3.14.RELEASE.jar:4.3.14.RELEASE]
at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.registerHandlerMethod(AbstractHandlerMethodMapping.java:264) ~[spring-webmvc-4.3.14.RELEASE.jar:4.3.14.RELEASE]
at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.detectHandlerMethods(AbstractHandlerMethodMapping.java:250) ~[spring-webmvc-4.3.14.RELEASE.jar:4.3.14.RELEASE]
at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.initHandlerMethods(AbstractHandlerMethodMapping.java:214) ~[spring-webmvc-4.3.14.RELEASE.jar:4.3.14.RELEASE]
at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.afterPropertiesSet(AbstractHandlerMethodMapping.java:184) ~[spring-webmvc-4.3.14.RELEASE.jar:4.3.14.RELEASE]
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping.afterPropertiesSet(RequestMappingHandlerMapping.java:127) ~[spring-webmvc-4.3.14.RELEASE.jar:4.3.14.RELEASE]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1687) ~[spring-beans-4.3.14.RELEASE.jar:4.3.14.RELEASE]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1624) ~[spring-beans-4.3.14.RELEASE.jar:4.3.14.RELEASE]
... 21 common frames omitted
錯(cuò)誤原因是這里繼承的接口類是一個(gè)controller接口,繼承時(shí)會(huì)繼承到父類的
@RequestMapping("/demo/api")
SpringMvc在做mapping映射的時(shí)候發(fā)現(xiàn)ConsumerFeignService和ConsumerFeignServiceFallBack的mapping重復(fù)了,所以拋出異常,如何解決呢?
解決的方法有2個(gè):
一是更改ConsumerFeignServiceFallBack的mapping配置,代碼如下:
@Component
@RequestMapping("fallback/demo/api")
public class ConsumerFeignServiceFallBack implements ConsumerFeignService {
@Override
public User getUserById(long id) {
return new User();
}
@Override
public String echo(String name) {
return "echo error: " + name;
}
}
二是使用fallbackFactory,代碼如下:
@Component
public class ConsumerFeignServiceFallBack implements FallbackFactory<ConsumerFeignService> {
@Override
public ConsumerFeignService create(Throwable cause) {
return new ConsumerFeignService() {
@Override
public User getUserById(long id) {
return new User();
}
@Override
public String echo(String name) {
return "echo error: " + name;
}
};
}
}
運(yùn)行后,關(guān)閉服務(wù)提供者,發(fā)現(xiàn)熔斷并沒有生效,沒有像單獨(dú)使用@HystrixCommand時(shí)進(jìn)入fallback方法,查了很多方式,發(fā)現(xiàn)原來是feign的hystix的配置開關(guān)沒有打開
解決方法,在application.yml中增加配置如下:
feign: hystrix: enabled: true
在IntelliJ IDEA里也沒有這個(gè)配置的提示,還報(bào)告警告,不知道算不算是個(gè)BUG,這里我使用的版本是
springBootVersion = '1.5.10.RELEASE' springCloudVersion = 'Edgware.SR3'
以上就是我在使用feign時(shí)發(fā)現(xiàn)的一些小坑,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用Java實(shí)現(xiàn)大小寫轉(zhuǎn)換實(shí)例代碼
最近在開發(fā)項(xiàng)目中遇到一個(gè)比較好用的方法,那就是對(duì)字符串中的字母大小進(jìn)行轉(zhuǎn)換,所以下面這篇文章主要給大家介紹了關(guān)于如何使用Java實(shí)現(xiàn)大小寫轉(zhuǎn)換的相關(guān)資料,需要的朋友可以參考下2022-06-06
java連接mysql數(shù)據(jù)庫及測(cè)試是否連接成功的方法
這篇文章主要介紹了java連接mysql數(shù)據(jù)庫及測(cè)試是否連接成功的方法,結(jié)合完整實(shí)例形式分析了java基于jdbc連接mysql數(shù)據(jù)庫并返回連接狀態(tài)的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-09-09
JavaWeb實(shí)現(xiàn)RSA+AES混合加密
RSA+AES的混合加密時(shí),AES用于給傳輸?shù)臄?shù)據(jù)加密,然后通過RSA給AES的秘鑰加密,本文就來詳細(xì)的介紹一下如何實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
Spring MVC實(shí)現(xiàn)mysql數(shù)據(jù)庫增刪改查完整實(shí)例
這篇文章主要介紹了Spring MVC實(shí)現(xiàn)mysql數(shù)據(jù)庫增刪改查完整實(shí)例,從創(chuàng)建一個(gè)web項(xiàng)目開始,分享了項(xiàng)目結(jié)構(gòu)以及具體Java代碼和前端頁面等相關(guān)內(nèi)容,具有一定借鑒價(jià)值,需要的朋友可以了解下。2017-12-12
java使用CountDownLatch實(shí)現(xiàn)多線程協(xié)作
在多線程編程中,經(jīng)常需要實(shí)現(xiàn)一種機(jī)制來協(xié)調(diào)多個(gè)線程的執(zhí)行,以確保某些操作在所有線程完成后再進(jìn)行,CountDownLatch?就是?Java?并發(fā)包中提供的一種同步工具,下面我們就來看看如何使用CountDownLatch實(shí)現(xiàn)多線程協(xié)作吧2023-11-11
Java調(diào)用C++動(dòng)態(tài)庫超詳細(xì)步驟講解(附源碼)
C語言因其高效和接近硬件的特性,時(shí)常會(huì)被用在性能要求較高或者需要直接操作硬件的場(chǎng)合,這篇文章主要介紹了Java調(diào)用C++動(dòng)態(tài)庫的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-04-04

