查看: 1647|回复: 0

[Java代码] 详解Spring Cloud Feign 熔断配置的一些小坑

发表于 2018-5-4 08:00:02

1.在使用feign做服务调用时,使用继承的方式调用服务,加入Hystrix的熔断处理fallback配置时,会报错,已解决。 2.使用feign默认配置,熔断不生效,已解决。

最近在做微服务的学习,发现在使用feign做服务调用时,使用继承的方式调用服务,加入Hystrix的熔断处理fallback配置时,会报错,代码如下:

  1. @RequestMapping("/demo/api")
  2. public interface HelloApi {
  3. @GetMapping("user/{id}")
  4. User getUserById(@PathVariable("id") long id);
  5. @GetMapping("hello")
  6. String echo(@RequestParam("name") String name);
  7. }
复制代码
  1. @FeignClient(value = "ms-server", fallback = ConsumerFeignServiceFallBack.class)
  2. public interface ConsumerFeignService extends HelloApi {
  3. }
复制代码
  1. @Component
  2. public class ConsumerFeignServiceFallBack implements ConsumerFeignService {
  3. @Override
  4. public User getUserById(long id) {
  5. return new User();
  6. }
  7. @Override
  8. public String echo(String name) {
  9. return "echo error: " + name;
  10. }
  11. }
复制代码

报错如下:

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. @Component
  2. @RequestMapping("fallback/demo/api")
  3. public class ConsumerFeignServiceFallBack implements ConsumerFeignService {
  4. @Override
  5. public User getUserById(long id) {
  6. return new User();
  7. }
  8. @Override
  9. public String echo(String name) {
  10. return "echo error: " + name;
  11. }
  12. }
复制代码

二是使用fallbackFactory,代码如下:

  1. @Component
  2. public class ConsumerFeignServiceFallBack implements FallbackFactory<ConsumerFeignService> {
  3. @Override
  4. public ConsumerFeignService create(Throwable cause) {
  5. return new ConsumerFeignService() {
  6. @Override
  7. public User getUserById(long id) {
  8. return new User();
  9. }
  10. @Override
  11. public String echo(String name) {
  12. return "echo error: " + name;
  13. }
  14. };
  15. }
  16. }
复制代码

运行后,关闭服务提供者,发现熔断并没有生效,没有像单独使用@HystrixCommand时进入fallback方法,查了很多方式,发现原来是feign的hystix的配置开关没有打开

解决方法,在application.yml中增加配置如下:

  1. feign:
  2. hystrix:
  3. enabled: true
复制代码

在IntelliJ IDEA里也没有这个配置的提示,还报告警告,不知道算不算是个BUG,这里我使用的版本是

  1. springBootVersion = '1.5.10.RELEASE'
  2. springCloudVersion = 'Edgware.SR3'
复制代码

以上就是我在使用feign时发现的一些小坑,希望对大家的学习有所帮助,也希望大家多多支持程序员之家。



回复

使用道具 举报