java学习Java学习笔记工作专题

Feign使用Hystrix无效原因及解决方法

2017-05-10  本文已影响77人  devzxd

最近项目重构使用了Spring Boot和Spring Cloud。这两者结合确实给项目带来了方便,同时也遇到了一些问题。其中使用feign作为服务消费,但是断路器hystrix一直不起作用让人很费解。最终经过重重查找终于找到原因,以及解决方法。

<h2> 问题产生原因</h2>

首先,使用spring-cloud搭建微服务的过程大部分是根据网上的教程来的,由于网上教程的时间较早,而spring-cloud更新迭代较快,会造成依赖上的一些问题。教程中的spring-cloud的依赖是

<dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-dependencies</artifactId>
        <version>Brixton.RELEASE</version>
        <type>pom</type>
        <scope>import</scope>
    </dependency>
    

而我自己使用idea搭建项目使用的是较新的依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-dependencies</artifactId>
    <version>Dalston.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>

发现两者的区别了吗?对!就是依赖版本不同。教程中的版本是 <code> Brixton.RELEASE</code> 而我使用的版本是<code>Dalston.RELEASE</code> 。

<h2>探究过程</h2>

根据这个关系顺藤摸瓜找到了Netflix的依赖版本

netflix依赖版本

接着,去了官网找到对应的版本,查看文档和API

mark

在文档中会看到


文档说明

这个意思就说feign默认是启用hystrix的,如果要禁用的话需要加配置语句。但是种种迹象表明,feign中并没有有启用hystrix,看到这里当时我就很疑惑,但是发现了hystrix在feign中的开关,还是有所收获的。我抱着试一试的心态照着上面的描述在配置文件中加上了配置,将<code>false</code>改为了<code>true</code>,结果神奇般的起了作用!

虽然问题解决了,为什么官方文档还是有错误的?在这里吐槽一句:TMD(挺萌的)~~~。

抱着追根求源的心态,查看了netflix的源码,看看什么时候修改了默认配置。点击上图中的API就可以看到源github上的源码了。里面这两段代码,就是管理默认配置的。

HystrixSecurityAutoConfiguration.java FeignClientsConfiguration.java

为什么要默认关闭hystrix呢?请看这里:https://github.com/spring-cloud/spring-cloud-netflix/issues/1277

至此,终于知道了产生错误的原因,以及为什么要默认关闭hystrix。

<h2> 解决方案</h2>

如果是yml文件,请在文件中加入:

feign:
  hystrix:
    enabled: true

如果是properties文件,请在文件中加入:

feign.hystrix.enabled=true

重启服务,大功告成!

本文首发地址:http://www.devzxd.top/2017/05/05/feign-hystrix-problem.html

上一篇下一篇

猜你喜欢

热点阅读