1.在使用feign做服務調用時,使用繼承的方式調用服務,加入hystrix的熔斷處理fallback配置時,會報錯,已解決。 2.使用feign默認配置,熔斷不生效,已解決。
最近在做微服務的學習,發現在使用feign做服務調用時,使用繼承的方式調用服務,加入hystrix的熔斷處理fallback配置時,會報錯,代碼如下:
1
2
3
4
5
6
7
8
9
|
@requestmapping ( "/demo/api" ) public interface helloapi { @getmapping ( "user/{id}" ) user getuserbyid( @pathvariable ( "id" ) long id); @getmapping ( "hello" ) string echo( @requestparam ( "name" ) string name); } |
1
2
3
4
|
@feignclient (value = "ms-server" , fallback = consumerfeignservicefallback. class ) public interface consumerfeignservice extends helloapi { } |
1
2
3
4
5
6
7
8
9
10
11
12
|
@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接口,繼承時會繼承到父類的
1
|
@requestmapping ( "/demo/api" ) |
springmvc在做mapping映射的時候發現consumerfeignservice和consumerfeignservicefallback的mapping重復了,所以拋出異常,如何解決呢?
解決的方法有2個:
一是更改consumerfeignservicefallback的mapping配置,代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
@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,代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
@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; } }; } } |
運行后,關閉服務提供者,發現熔斷并沒有生效,沒有像單獨使用@hystrixcommand時進入fallback方法,查了很多方式,發現原來是feign的hystix的配置開關沒有打開
解決方法,在application.yml中增加配置如下:
1
2
3
|
feign: hystrix: enabled: true |
在intellij idea里也沒有這個配置的提示,還報告警告,不知道算不算是個bug,這里我使用的版本是
1
2
|
springbootversion = '1.5.10.release' springcloudversion = 'edgware.sr3' |
以上就是我在使用feign時發現的一些小坑,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://my.oschina.net/u/1758970/blog/1798279