go-kit组件使用hystrix中间件

84 篇文章 3 订阅
31 篇文章 0 订阅

使用go-kit中间件时,一般在endpoint中进行中间件的开发。
在endpoint层插入hystrix中间件的插入。
endpoint.go

func MakeEndpoint (svc services.StringService) endpoint.Endpoint {
	return func(ctx context.Context, request interface{}) (response interface{}, err error) {
		req := request.(*StringService.Request)
		rep , err  := svc.Diff(ctx , req)
		return rep , err
	}
}

go-kit使我们更注重对服务逻辑的开发,对中间过程的省略会减少很多的错误发生。
main.go

package main

import (
	"balencegrpc/services"
	"balencegrpc/router"
	"balencegrpc/proto"
	"balencegrpc/discover"
	"balencegrpc/endpoints"
	"github.com/go-kit/kit/circuitbreaker"
	"google.golang.org/grpc"
	"google.golang.org/grpc/health/grpc_health_v1"
	"log"
	"net"
)

func main() {
	//svc := new()
	 svc := services.ServiceI{}
	endpoint := circuitbreaker.Hystrix("testname")(endpoints.MakeEndpoint(svc))
	lis , err := net.Listen("tcp" , ":8081")
	if err != nil {
		log.Println(err)
		return
	}
	router := router.NewRouter(svc , endpoint)
	grpcserver := grpc.NewServer()
	c := discover.Service{}
	grpc_health_v1.RegisterHealthServer(grpcserver , &c)
	StringService.RegisterStringServiceServer(grpcserver , router)
	rs := discover.NewService()
	rs.Register("127.0.0.1" , 8081)
	grpcserver.Serve(lis)
}

我们在main.go中进行添加hystrix对endpoint进行封装,,使用hystrix进行服务熔断的处理。其实使用go-kit封装的。也可以自行封装一个中间件,在创建endpoint时进行封装

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值