我们需要统一的rpc服务,经过选型讨论决定直接使用成熟的跨语言的gRPC。
- 不改gRPC源码,基于接口进行包装集成trace、log、prom等组件
- 打通自有服务注册发现系统discovery
- 实现更平滑可靠的负载均衡算法
gRPC暴露了两个拦截器接口,分别是:
grpc.UnaryServerInterceptor
服务端拦截器grpc.UnaryClientInterceptor
客户端拦截器
基于两个拦截器可以针对性的定制公共模块的封装代码,比如warden/logging.go
是通用日志逻辑。
gRPC暴露了服务发现的接口resolver.Resolver
,warden/resolver/resolver.go
实现了该接口,并基于了pkg/naming/naming.go
内的Resolver
接口进行Fetch``Watch
等操作。
pkg/naming/discovery/discovery.go
内实现了pkg/naming/naming.go
内的Resolver
接口,使用discovery来进行服务发现。
注意:pkg/naming/naming.go
内的Resolver
接口是kratos
的一层封装,暴露的接口主要:
- 相对原生
resolver.Resolver
内ResolveNow
更友好的方法Fetch``Watch
- 统一应用的实例信息结构体
naming.Instance
想要用非discovery的请参考下面文档进行开发。
实现了wrr
和p2c
两种算法,默认使用p2c
。
warden快速开始 warden拦截器 warden负载均衡 warden基于pb生成 warden服务发现