Feign与Hystrix

Feign默认已经整合了hystrix,只是默认是没有启用的,需要进行配置

feign:
  hystrix:
    enabled: true

可以看到如果配置了feign.hystrix.enabled会使用HystrixFeign.builder()来构建Feign,将具体的调用包裹在HystrixCommand 中

@Configuration(proxyBeanMethods = false)
@ConditionalOnClass({ HystrixCommand.class, HystrixFeign.class })
protected static class HystrixFeignConfiguration {

   @Bean
   @Scope("prototype")
   @ConditionalOnMissingBean
   @ConditionalOnProperty(name = "feign.hystrix.enabled")
   public Feign.Builder feignHystrixBuilder() {
      return HystrixFeign.builder();
   }

}
和 Feign 使用的时候需要注意错误处理的问题。对于一些非功能性的业务错误,需要包装为 HystrixBadRequestException,让 Hystrix 不要统计到错误中造成断路

虽然开启了hystrix,但是其默认不带有监控端点,如果想要使用监控端点,需要加依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>

然后启动类上增加@EnableCircuitBreaker注解,并开启端点

management:
  endpoints:
    web:
      exposure:
        include: 'hystrix.stream'

参考文献


bug生产者
20 声望0 粉丝