mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-15 06:28:20 +00:00
7cc32c4dda
* remove unused code * remove defer use in loop * Remove unused methods and constants * gofmt and gaz * nilness check * remove unused args * Add TODO for refactoring subscribeWithBase to remove unused arg. It seems too involved to include in this sweeping PR. https://github.com/prysmaticlabs/prysm/issues/7437 * replace empty slice declaration * Remove unnecessary type conversions * remove redundant type declaration * rename receivers to be consistent * Remove bootnode query tool. It is now obsolete by discv5 * Remove relay node. It is no longer used or supported * Revert "Remove relay node. It is no longer used or supported" This reverts commit 4bd7717334dad85ef4766ed9bc4da711fb5fa810. * Delete unused test directory * Delete unsupported gcp startup script * Delete old k8s script * build fixes * fix build * go mod tidy * revert slasher/db/kv/block_header.go * fix build * remove redundant nil check * combine func args Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com> Co-authored-by: Victor Farazdagi <simple.square@gmail.com>
47 lines
1.5 KiB
Go
47 lines
1.5 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{}
|
|
|
|
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
|
|
}
|
|
|
|
func (*multipleEndpointsGrpcResolverBuilder) Scheme() string {
|
|
return resolver.GetDefaultScheme()
|
|
}
|
|
|
|
type multipleEndpointsGrpcResolver struct {
|
|
target resolver.Target
|
|
cc resolver.ClientConn
|
|
}
|
|
|
|
func (r *multipleEndpointsGrpcResolver) start() {
|
|
endpoints := strings.Split(r.target.Endpoint, ",")
|
|
var addrs []resolver.Address
|
|
for _, endpoint := range endpoints {
|
|
addrs = append(addrs, resolver.Address{Addr: endpoint})
|
|
}
|
|
r.cc.UpdateState(resolver.State{Addresses: addrs})
|
|
}
|
|
|
|
func (*multipleEndpointsGrpcResolver) ResolveNow(_ resolver.ResolveNowOptions) {}
|
|
|
|
func (*multipleEndpointsGrpcResolver) Close() {}
|