mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-09 19:21:19 +00:00
54 lines
1.8 KiB
Go
54 lines
1.8 KiB
Go
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{}
|
|
|
|
// Build creates and starts multiple endpoints resolver.
|
|
func (*multipleEndpointsGrpcResolverBuilder) Build(target resolver.Target, cc resolver.ClientConn, _ resolver.BuildOptions) (resolver.Resolver, error) {
|
|
r := &multipleEndpointsGrpcResolver{
|
|
target: target,
|
|
cc: cc,
|
|
}
|
|
r.start()
|
|
return r, nil
|
|
}
|
|
|
|
// Scheme returns default scheme.
|
|
func (*multipleEndpointsGrpcResolverBuilder) Scheme() string {
|
|
return resolver.GetDefaultScheme()
|
|
}
|
|
|
|
type multipleEndpointsGrpcResolver struct {
|
|
target resolver.Target
|
|
cc resolver.ClientConn
|
|
}
|
|
|
|
func (r *multipleEndpointsGrpcResolver) start() {
|
|
ep := r.target.Endpoint()
|
|
endpoints := strings.Split(ep, ",")
|
|
var addrs []resolver.Address
|
|
for _, endpoint := range endpoints {
|
|
addrs = append(addrs, resolver.Address{Addr: endpoint, ServerName: endpoint})
|
|
}
|
|
if err := r.cc.UpdateState(resolver.State{Addresses: addrs}); err != nil {
|
|
log.WithError(err).Error("Failed to update grpc connection state")
|
|
}
|
|
}
|
|
|
|
// ResolveNow --
|
|
func (*multipleEndpointsGrpcResolver) ResolveNow(_ resolver.ResolveNowOptions) {}
|
|
|
|
// Close --
|
|
func (*multipleEndpointsGrpcResolver) Close() {}
|