詳解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è)計(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)的十大排序,排序算法分為比較類排序和非比較類排序,具體的內(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-01
Java線程池的幾種實(shí)現(xiàn)方法和區(qū)別介紹實(shí)例詳解
本篇文章主要介紹了Java線程池的幾種實(shí)現(xiàn)方法和區(qū)別,需要的朋友可以參考2017-04-04
SpringBoot如何實(shí)現(xiàn)接口版本控制
這篇文章主要介紹了SpringBoot如何實(shí)現(xiàn)接口版本控制,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
java控制臺(tái)實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(IO版)
這篇文章主要為大家詳細(xì)介紹了java控制臺(tái)實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(IO版),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04
SpringBoot對(duì)Jar包進(jìn)行加密的示例代碼
在當(dāng)今互聯(lián)網(wǎng)高速發(fā)展的時(shí)代,軟件安全問題變得尤為突出,隨著開源技術(shù)的普及,Spring Boot等框架的應(yīng)用越來越廣泛,但也伴隨著代碼被反編譯的風(fēng)險(xiǎn),本文將探討在Spring Boot項(xiàng)目中對(duì)Jar包進(jìn)行加密,以防止反編譯的安全實(shí)踐,需要的朋友可以參考下2023-12-12
Java多線程中的ReentrantLock可中斷鎖詳細(xì)解讀
這篇文章主要介紹了Java多線程中的ReentrantLock可中斷鎖詳細(xì)解讀,ReentrantLock中的lockInterruptibly()方法使得線程可以在被阻塞時(shí)響應(yīng)中斷,比如一個(gè)線程t1通過lockInterruptibly()方法獲取到一個(gè)可重入鎖,并執(zhí)行一個(gè)長(zhǎng)時(shí)間的任務(wù),需要的朋友可以參考下2023-12-12

