亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

生產技巧:Feign如何控制Hystrix的啟停、超時、熔斷?

標簽:
Spring Cloud

这也是一篇写于2017-08前后的工作日志,当时由于项目比较多,很多团队对Feign和Hystrix之间的小暧昧搞不清楚,所以写了本篇文章,希望对大家的工作有所帮助。

  1. 要想全局关闭Hystrix,只需使用如下配置即可:

    feign.hystrix.enabled: false

    这样,就会为所有服务关闭掉Feign的Hystrix支持。也就是说:A服务调用B服务,如果在A服务上设置该属性,A服务的所有Feign Client都不会再有Hystrix熔断的能力了。

  2. 全局配置够灵活,一般不能满足实际项目的要求。实际项目中,往往需要精确到指定服务的细粒度配置。例如:调用服务a时关闭Hystrix,调用b服务时打开Hystrix。可如下配置:

    @FeignClient(name="a", configuration = FooConfiguration.class)

    那么,这个FooConfiguration只需要编写如下即可:

    public class FooConfiguration {    @Bean
     @Scope("prototype") public Feign.Builder feignBuilder() {     return Feign.builder();
     }
    }

    这样,对于name = "a" 的Feign Client都会关闭Hystrix支持。

  3. 很多场景下,关闭Hystrix相对暴力,特别是上文编写代码的方式。很多时候,我们可能更希望只是关闭熔断,抑或是关闭超时保护。此时要怎么搞呢?

    关闭熔断:

    # 全局关闭熔断:hystrix.command.default.circuitBreaker.enabled: false# 局部关闭熔断:hystrix.command.<HystrixCommandKey>.circuitBreaker.enabled: false

    设置超时:

    # 全局设置超时:hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 1000
    # 局部设置超时:hystrix.command.<HystrixCommandKey>.execution.isolation.thread.timeoutInMilliseconds: 1000

    关闭超时:

    # 全局关闭:hystrix.command.default.execution.timeout.enabled: false# 局部关闭:hystrix.command.<HystrixCommandKey>.execution.timeout.enabled: false

    其中的<HystrixCommandKey> ,是个变量,可以打开服务的hystrix.stream 端点即可看到,也可在Hystrix Dashboard中查看。

本文首发

http://www.itmuch.com/spring-cloud-sum/feign-hystrix/





點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
架構師
手記
粉絲
6633
獲贊與收藏
1784

關注作者,訂閱最新文章

閱讀免費教程

  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消