go micro 微服务添加熔断器

  • 需要的包

    go get github.com/afex/hystrix-go/hystrix 
  • 需要先进行包装

    // go-micro main.go 里面 New Service 添加上熔断器即可
    service := micro.NewService(
        micro.Name("go.micro.api.cartApi"),
        micro.Version("latest"),
        micro.Address(":8085"),
        //添加consul注册中心
        micro.Registry(consul),
        //添加链路追踪
        micro.WrapClient(opentracing2.NewClientWrapper(opentracing.GlobalTracer())),
        //添加熔断
        micro.WrapClient(NewClientHystrixWrapper()),
    )
    //下面对熔断器包装
    type clientWrapper struct {
    client.Client
    }
    func (c *clientWrapper) Call(ctx context.Context,req client.Request,rsp interface{},opts ...client.CallOption) error  {
    return hystrix.Do(req.Service()+"."+req.Endpoint(), func() error {
        //run 正常执行逻辑
        fmt.Println("req.Service()+req.Endpoint()值:")
        fmt.Println(req.Service()+"."+req.Endpoint())
        return c.Client.Call(ctx,req,rsp,opts ...)
    }, func(err error) error {
        //
        fmt.Println(err)
        return err
    })
    }
    func NewClientHystrixWrapper() client.Wrapper {
    return func(i client.Client) client.Client {
        return &clientWrapper{i}
    }
    }

go micro 微服务添加熔断器

go micro 微服务添加熔断器

原创文章,作者:星辰,如若转载,请注明出处:https://www.z88j.com/39297.html

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 2022年2月22日 下午10:54
下一篇 2022年2月24日 下午10:46

相关推荐

发表回复

登录后才能评论

Warning: error_log(/www/wwwroot/www.z88j.com/wp-content/plugins/spider-analyser/#log/log-2705.txt): failed to open stream: No such file or directory in /www/wwwroot/www.z88j.com/wp-content/plugins/spider-analyser/spider.class.php on line 2900