分享
  1. 首页
  2. 文章

hystrix-go

GoSnail · · 2768 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

内部组织了一次关于hystrix-go的分享,没想到引起了内部的困惑,对于没有做过分布式系统的开发同学可能根本没有接触过hystrix,学习一个新东西,我个人的一贯思路是按照黄金圈理论。


这里关于hystrix是什么就不描述了,百度一下足够你翻几屏的了。

因为目前Team以golang为主要开发语言,所以使用了开源的hystrix-go(https://github.com/afex/hystrix-go).

大家先看下面一个例子:

var Number int

var Result string

func main() {

config := hystrix.CommandConfig{

Timeout:2000, //超时时间设置 单位毫秒

MaxConcurrentRequests:8, //最大请求数

SleepWindow:1, //过多长时间,熔断器再次检测是否开启。单位毫秒

ErrorPercentThreshold:30, //错误率

RequestVolumeThreshold:5, //请求阈值 熔断器是否打开首先要满足这个条件;这里的设置表示至少有5个请求才进行ErrorPercentThreshold错误百分比计算

}

hystrix.ConfigureCommand("test",config)

cbs,_,_:= hystrix.GetCircuit("test")

defer hystrix.Flush()

for i:= 0;i < 50 ;i++ {

start1 := time.Now()

Number = i

hystrix.Go("test",run ,getFallBack)

fmt.Println("请求次数:",i +1,";用时:",time.Now().Sub(start1),";请求状态 :",Result,";熔断器开启状态:",cbs.IsOpen(),"请求是否允许:",cbs.AllowRequest())

time.Sleep(1000 * time.Millisecond)

}

time.Sleep(20 * time.Second)

}

func run()error {

Result ="RUNNING1"

if Number >10 {

return nil

}

if Number %2 ==0 {

return nil

} else {

return errors.New("请求失败")

}

}

func getFallBack(errerror) error {

Result ="FALLBACK"

return nil

}

这是一个同事分享时讲的一个列子(不知这个例子的具体出路),也就是这个例子,把大家搞晕了〜〜。

大家可能会预期输出第一次i == 0,对2取余为0,然后输出

请求次数: 1 ;用时: 12.002μs ;请求状态 : ;熔断器开启状态: false 请求是否允许: true

请求次数: 2 ;用时: 131.926μs ;请求状态 : RUNNING1 ;熔断器开启状态: false 请求是否允许: true

然后依次循环,当到第11次时,对2取余不为9的次数为5,到达RequestVolumeThreshold设定的5,所以熔断器开启,此后的处理不会进入到run函数,直到SleepWindow时间到,会开启重试。

然后大家可以运行下上面的程序试试,实际并非如此。这里存在对大家两个知识点的掌握程度考验,1:go协程。2、hystrix-go的配置参数含义理解。

对于知识点1,这里不再做解释了,请查看上一篇文章,https://www.jianshu.com/writer#/notebooks/27310466/notes/30733785。

讲上面的例子稍微修改下,增加runtime.GOMAXPROCS(1),就能够达到上面的预期了吗?然而并没有,如果这里还没有理解,说明大家没有仔细看我上面提到的那个文章,或者说看了没有看透。

那么究竟怎么做才能达到我们心里预期那?

大家细看下hystrix-go源码或readme,实际上hystrix提供了hystrix.Go、hystrix.GoC、hystrix.Do、hystrix.DoC这四种方法。顾名思义,GoX代表异步调用处理,DoX代表同步处理,因此将上面的例子中的hystrix.Go改成hystrix.Do,基本可以输出之前的预期结果,但是细心的人仔细查看输出结果其实并不对。接下来主要讨论下hystrix.CommandConfig{

Timeout:2000, //超时时间设置 单位毫秒

MaxConcurrentRequests:8, //最大请求数

SleepWindow:1, //过多长时间,熔断器再次检测是否开启。单位毫秒

ErrorPercentThreshold:30, //错误率

RequestVolumeThreshold:5, //请求阈值 熔断器是否打开首先要满足这个条件;这里的设置表示至少有5个请求才进行ErrorPercentThreshold错误百分比计算

}这里的几个参数。

Timeout,顾名思义就是指运行run函数的超时时间,如果超时,熔断器失败次数+1,这里可以将run函数里面增加个大于timeout的延时看看效果?然后在getFallBack函数里面打印下err,会hystrix: timeout这个错误输出。

再说下SleepWindow这个参数。按照上面的例子,会有如下的打印

请求次数: 11 ;用时: 164.183μs ;请求状态 : RUNNING1 ;熔断器开启状态: false 请求是否允许: true

请求次数: 12 ;用时: 117.482μs ;请求状态 : FALLBACK ;熔断器开启状态: true 请求是否允许: false

请求次数: 13 ;用时: 184.445μs ;请求状态 : RUNNING1 ;熔断器开启状态: false 请求是否允许: true

熔断器状态在12个请求开启了一次,立刻关闭了,这就是因为sleepWindow时间很短(1ms),熔断器再次检测ok后,立马改变了熔断器状态。


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:GoSnail

查看原文:hystrix-go

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
2768 次点击 ∙ 1 赞
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏