詳解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ò)誤原因是這里繼承的接口類(lèi)是一個(gè)controller接口,繼承時(shí)會(huì)繼承到父類(lèi)的
@RequestMapping("/demo/api")
SpringMvc在做mapping映射的時(shí)候發(fā)現(xiàn)ConsumerFeignService和ConsumerFeignServiceFallBack的mapping重復(fù)了,所以?huà)伋霎惓?,如何解決呢?
解決的方法有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)熔斷并沒(méi)有生效,沒(méi)有像單獨(dú)使用@HystrixCommand時(shí)進(jìn)入fallback方法,查了很多方式,發(fā)現(xiàn)原來(lái)是feign的hystix的配置開(kāi)關(guān)沒(méi)有打開(kāi)
解決方法,在application.yml中增加配置如下:
feign: hystrix: enabled: true
在IntelliJ IDEA里也沒(méi)有這個(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è)計(jì)模式學(xué)習(xí)之簡(jiǎn)單工廠模式
這篇文章主要為大家詳細(xì)介紹了java設(shè)計(jì)模式學(xué)習(xí)之簡(jiǎn)單工廠模式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10?Java數(shù)據(jù)結(jié)構(gòu)的十大排序
這篇文章主要介紹了?Java數(shù)據(jù)結(jié)構(gòu)的十大排序,排序算法分為比較類(lèi)排序和非比較類(lèi)排序,具體的內(nèi)容,需要的朋友參考下面思維導(dǎo)圖及文章介紹,希望對(duì)你有所幫助2022-01-01基于Java實(shí)現(xiàn)抽獎(jiǎng)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于Java實(shí)現(xiàn)抽獎(jiǎng)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01Java線(xiàn)程池的幾種實(shí)現(xiàn)方法和區(qū)別介紹實(shí)例詳解
本篇文章主要介紹了Java線(xiàn)程池的幾種實(shí)現(xiàn)方法和區(qū)別,需要的朋友可以參考2017-04-04SpringBoot如何實(shí)現(xiàn)接口版本控制
這篇文章主要介紹了SpringBoot如何實(shí)現(xiàn)接口版本控制,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10java控制臺(tái)實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(IO版)
這篇文章主要為大家詳細(xì)介紹了java控制臺(tái)實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(IO版),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04SpringBoot對(duì)Jar包進(jìn)行加密的示例代碼
在當(dāng)今互聯(lián)網(wǎng)高速發(fā)展的時(shí)代,軟件安全問(wèn)題變得尤為突出,隨著開(kāi)源技術(shù)的普及,Spring Boot等框架的應(yīng)用越來(lái)越廣泛,但也伴隨著代碼被反編譯的風(fēng)險(xiǎn),本文將探討在Spring Boot項(xiàng)目中對(duì)Jar包進(jìn)行加密,以防止反編譯的安全實(shí)踐,需要的朋友可以參考下2023-12-12Java多線(xiàn)程中的ReentrantLock可中斷鎖詳細(xì)解讀
這篇文章主要介紹了Java多線(xiàn)程中的ReentrantLock可中斷鎖詳細(xì)解讀,ReentrantLock中的lockInterruptibly()方法使得線(xiàn)程可以在被阻塞時(shí)響應(yīng)中斷,比如一個(gè)線(xiàn)程t1通過(guò)lockInterruptibly()方法獲取到一個(gè)可重入鎖,并執(zhí)行一個(gè)長(zhǎng)時(shí)間的任務(wù),需要的朋友可以參考下2023-12-12