2020-09-27 18:08:28 +00:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"google.golang.org/grpc/resolver"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Modification of a default grpc passthrough resolver (google.golang.org/grpc/resolver/passthrough) allowing to use multiple addresses
|
|
|
|
// in grpc endpoint. Example:
|
|
|
|
// conn, err := grpc.DialContext(ctx, "127.0.0.1:4000,127.0.0.1:4001", grpc.WithInsecure(), grpc.WithResolvers(&multipleEndpointsGrpcResolverBuilder{}))
|
|
|
|
// It can be used with any grpc load balancer (pick_first, round_robin). Default is pick_first.
|
|
|
|
// Round robin can be used by adding the following option:
|
|
|
|
// grpc.WithDefaultServiceConfig("{\"loadBalancingConfig\":[{\"round_robin\":{}}]}")
|
|
|
|
type multipleEndpointsGrpcResolverBuilder struct{}
|
|
|
|
|
2021-04-23 12:06:05 +00:00
|
|
|
// Build creates and starts multiple endpoints resolver.
|
2020-10-12 08:11:05 +00:00
|
|
|
func (*multipleEndpointsGrpcResolverBuilder) Build(target resolver.Target, cc resolver.ClientConn, _ resolver.BuildOptions) (resolver.Resolver, error) {
|
2020-09-27 18:08:28 +00:00
|
|
|
r := &multipleEndpointsGrpcResolver{
|
|
|
|
target: target,
|
|
|
|
cc: cc,
|
|
|
|
}
|
|
|
|
r.start()
|
|
|
|
return r, nil
|
|
|
|
}
|
|
|
|
|
2021-04-23 12:06:05 +00:00
|
|
|
// Scheme returns default scheme.
|
2020-09-27 18:08:28 +00:00
|
|
|
func (*multipleEndpointsGrpcResolverBuilder) Scheme() string {
|
|
|
|
return resolver.GetDefaultScheme()
|
|
|
|
}
|
|
|
|
|
|
|
|
type multipleEndpointsGrpcResolver struct {
|
|
|
|
target resolver.Target
|
|
|
|
cc resolver.ClientConn
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *multipleEndpointsGrpcResolver) start() {
|
2023-07-22 08:19:23 +00:00
|
|
|
ep := r.target.Endpoint()
|
|
|
|
endpoints := strings.Split(ep, ",")
|
2020-09-27 18:08:28 +00:00
|
|
|
var addrs []resolver.Address
|
|
|
|
for _, endpoint := range endpoints {
|
2022-10-17 14:59:17 +00:00
|
|
|
addrs = append(addrs, resolver.Address{Addr: endpoint, ServerName: endpoint})
|
2020-09-27 18:08:28 +00:00
|
|
|
}
|
2021-12-01 18:09:34 +00:00
|
|
|
if err := r.cc.UpdateState(resolver.State{Addresses: addrs}); err != nil {
|
|
|
|
log.WithError(err).Error("Failed to update grpc connection state")
|
|
|
|
}
|
2020-09-27 18:08:28 +00:00
|
|
|
}
|
|
|
|
|
2021-04-23 12:06:05 +00:00
|
|
|
// ResolveNow --
|
2020-10-12 08:11:05 +00:00
|
|
|
func (*multipleEndpointsGrpcResolver) ResolveNow(_ resolver.ResolveNowOptions) {}
|
2020-09-27 18:08:28 +00:00
|
|
|
|
2021-04-23 12:06:05 +00:00
|
|
|
// Close --
|
2020-09-27 18:08:28 +00:00
|
|
|
func (*multipleEndpointsGrpcResolver) Close() {}
|