具体例子请参考: grpc-registry-go/examples/helloworld
grpc-registry-go 基于grpc-go之上封装了注册中心的功能,支持基于健康检查的自动上下线。 grpc-registry-go 是以应用为维度的服务注册和服务发现,当前实现了etcd 方式的服务注册和服务发现。
如果要实现其他类型的registry, 只需要实现 IRegistry 和 IRegistryFactory 两个接口即可, 如果要实现其他类型的服务发现, 只需要实现 IConnFactory 接口即可
- 配置server端 config (server_config.yaml)
最小化配置, 更多配置请查看 grpc-registry-go/server/server_config.go
app_name: testApp
port: 8888
schema: etcd
etcd_registry_config:
endpoints:
- 'etcd.server.addr:2379'
- protobuf声明一个rpc 服务,并暴露服务端 stub
example 定义grpc-registry-go/examples/hellworld/stub/hello.proto
syntax = "proto3";
package hello;
option go_package = "demo/hello";
service Greeter {
rpc SayHello(HelloRequest) returns (HelloReply) {}
}
message HelloRequest {
string name = 1;
}
message HelloReply {
string message = 1;
}
- 编译 protobuf
protoc --go_out=. --go_opt=paths=source_relative --go-grpc_out=. --go-grpc_opt=paths=source_relative helloworld/stub/hello.proto
- 业务代码
type greeterServiceImpl struct {
hello.UnimplementedGreeterServer
}
func (g *greeterServiceImpl) SayHello(ctx context.Context, in *hello.HelloRequest) (*hello.HelloReply, error) {
log.Printf("received request: %s\n", in.GetName())
return &hello.HelloReply{Message: "Hello " + in.GetName()}, nil
}
func main() {
// 初始化config
cfg := ....
// 初始化 gserver
gs, err := gserver.New(cfg).Build()
if err != nil {
log.Fatalln(err)
}
// 注册服务
hello.RegisterGreeterServer(gs.Server(), &greeterServiceImpl{})
// gserver run
log.Fatalln(gs.Run())
}
- 配置client端config (client_config.yaml)
最小化配置,更多配置请查看 grpc-registry-go/config/client_config.go
servers_discovery:
- server_app: testApp
schema: etcd
etcd_config:
endpoints:
- 'etcd.server.addr:2379'
- 业务代码
func main() {
// 初始化config
cfg := ....
// 初始化 gclient
c, err := gclient.New(cfg).Build()
if err != nil {
log.Fatalln(err)
}
greeterClient := hello.NewGreeterClient(c.GetConn("serverApp"))
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
defer cancel()
r, err := greeterClient.SayHello(ctx, &hello.HelloRequest{Name: "charles"})
if err != nil {
log.Fatalln(err)
}
log.Println("Greeting: ", r)
}
特性:
1. WithHealthcheck(checker healthcheck.IHealthChecker)
支持业务健康检查, 业务只需要实现 healthcheck.IHealthChecker 接口即可, 当IsHealth() 返回为true时代表业务正常,gserver便将自己注册到注册中心
当 IsHealtch() 返回false时代表业务不正常, gserver便将自己从应用中心债除掉.
默认没有healthcheck, server启动便将自己注册到注册中心
2. WithServerOptions(options ...grpc.ServerOption)
指定自定义的grpc.ServerOption, 默认的grpc.ServerOption有 grpc.ConnectionTimeout(60 * time.Second), 60s连接超时
3. WithLogger(logger *zap.Logger)
指定logger
特性:
1. WithDialOptions(options ...grpc.DialOption)
指定自定义的grpc.DialOption, 默认的DialOption 有
// 默认通讯不指定证书
grpc.WithTransportCredentials(insecure.NewCredentials())
// 默认的负载均衡策略是轮询, 若要更换策略,可以在client config的BalancePolicy中指定
grpc.WithDefaultServiceConfig(`{"loadBalancingPolicy":"round_robin"}`)
注意: 通常不要自己指定resolvers grpc.WithResolvers(), resolver和对应的注册中心成对出现, gclient中已经默认实现了
2. WithLogger(logger *zap.Logger)
指定logger
3. WithContext(ctx context.Context)
指定 context, 此context会被用于 grpc.DialContext(ctx, ...)