詳解Spring Cloud Feign 熔斷配置的一些小坑
1.在使用feign做服務(wù)調(diào)用時,使用繼承的方式調(diào)用服務(wù),加入Hystrix的熔斷處理fallback配置時,會報錯,已解決。 2.使用feign默認(rèn)配置,熔斷不生效,已解決。
最近在做微服務(wù)的學(xué)習(xí),發(fā)現(xiàn)在使用feign做服務(wù)調(diào)用時,使用繼承的方式調(diào)用服務(wù),加入Hystrix的熔斷處理fallback配置時,會報錯,代碼如下:
@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;
}
}
報錯如下:
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
錯誤原因是這里繼承的接口類是一個controller接口,繼承時會繼承到父類的
@RequestMapping("/demo/api")
SpringMvc在做mapping映射的時候發(fā)現(xiàn)ConsumerFeignService和ConsumerFeignServiceFallBack的mapping重復(fù)了,所以拋出異常,如何解決呢?
解決的方法有2個:
一是更改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;
}
};
}
}
運行后,關(guān)閉服務(wù)提供者,發(fā)現(xiàn)熔斷并沒有生效,沒有像單獨使用@HystrixCommand時進(jìn)入fallback方法,查了很多方式,發(fā)現(xiàn)原來是feign的hystix的配置開關(guān)沒有打開
解決方法,在application.yml中增加配置如下:
feign: hystrix: enabled: true
在IntelliJ IDEA里也沒有這個配置的提示,還報告警告,不知道算不算是個BUG,這里我使用的版本是
springBootVersion = '1.5.10.RELEASE' springCloudVersion = 'Edgware.SR3'
以上就是我在使用feign時發(fā)現(xiàn)的一些小坑,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java設(shè)計模式學(xué)習(xí)之簡單工廠模式
這篇文章主要為大家詳細(xì)介紹了java設(shè)計模式學(xué)習(xí)之簡單工廠模式,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10
?Java數(shù)據(jù)結(jié)構(gòu)的十大排序
這篇文章主要介紹了?Java數(shù)據(jù)結(jié)構(gòu)的十大排序,排序算法分為比較類排序和非比較類排序,具體的內(nèi)容,需要的朋友參考下面思維導(dǎo)圖及文章介紹,希望對你有所幫助2022-01-01
Java線程池的幾種實現(xiàn)方法和區(qū)別介紹實例詳解
本篇文章主要介紹了Java線程池的幾種實現(xiàn)方法和區(qū)別,需要的朋友可以參考2017-04-04
java控制臺實現(xiàn)學(xué)生信息管理系統(tǒng)(IO版)
這篇文章主要為大家詳細(xì)介紹了java控制臺實現(xiàn)學(xué)生信息管理系統(tǒng)(IO版),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-04-04
Java多線程中的ReentrantLock可中斷鎖詳細(xì)解讀
這篇文章主要介紹了Java多線程中的ReentrantLock可中斷鎖詳細(xì)解讀,ReentrantLock中的lockInterruptibly()方法使得線程可以在被阻塞時響應(yīng)中斷,比如一個線程t1通過lockInterruptibly()方法獲取到一個可重入鎖,并執(zhí)行一個長時間的任務(wù),需要的朋友可以參考下2023-12-12

