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

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

问题产生原因

首先,使用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>

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

探究过程

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

netflix依赖版本

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

mark

在文档中会看到
文档说明

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

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

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

HystrixSecurityAutoConfiguration.java

FeignClientsConfiguration.java

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

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

解决方案

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

feign:
  hystrix:
    enabled: true

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

feign.hystrix.enabled=true

重启服务,大功告成!

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

posted @ 2017-05-09 11:11  devzxd  阅读(30897)  评论(1编辑  收藏  举报