|
@ -76,43 +76,33 @@ func GrpcDial(ctx context.Context, address string, opts ...grpc.DialOption) (*gr |
|
|
return grpc.DialContext(ctx, address, options...) |
|
|
return grpc.DialContext(ctx, address, options...) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func WithCachedGrpcClient(fn func(*grpc.ClientConn) error, address string, opts ...grpc.DialOption) error { |
|
|
|
|
|
|
|
|
func getOrCreateConnection(address string, opts ...grpc.DialOption) (*grpc.ClientConn, error) { |
|
|
|
|
|
|
|
|
grpcClientsLock.Lock() |
|
|
grpcClientsLock.Lock() |
|
|
|
|
|
defer grpcClientsLock.Unlock() |
|
|
|
|
|
|
|
|
existingConnection, found := grpcClients[address] |
|
|
existingConnection, found := grpcClients[address] |
|
|
if found { |
|
|
if found { |
|
|
grpcClientsLock.Unlock() |
|
|
|
|
|
err := fn(existingConnection) |
|
|
|
|
|
if err != nil { |
|
|
|
|
|
grpcClientsLock.Lock() |
|
|
|
|
|
// delete(grpcClients, address)
|
|
|
|
|
|
grpcClientsLock.Unlock() |
|
|
|
|
|
// println("closing existing connection to", existingConnection.Target())
|
|
|
|
|
|
// existingConnection.Close()
|
|
|
|
|
|
} |
|
|
|
|
|
return err |
|
|
|
|
|
|
|
|
return existingConnection, nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
grpcConnection, err := GrpcDial(context.Background(), address, opts...) |
|
|
grpcConnection, err := GrpcDial(context.Background(), address, opts...) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
grpcClientsLock.Unlock() |
|
|
|
|
|
return fmt.Errorf("fail to dial %s: %v", address, err) |
|
|
|
|
|
|
|
|
return nil, fmt.Errorf("fail to dial %s: %v", address, err) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
grpcClients[address] = grpcConnection |
|
|
grpcClients[address] = grpcConnection |
|
|
grpcClientsLock.Unlock() |
|
|
|
|
|
|
|
|
|
|
|
err = fn(grpcConnection) |
|
|
|
|
|
if err != nil { |
|
|
|
|
|
grpcClientsLock.Lock() |
|
|
|
|
|
// delete(grpcClients, address)
|
|
|
|
|
|
grpcClientsLock.Unlock() |
|
|
|
|
|
// println("closing created new connection to", grpcConnection.Target())
|
|
|
|
|
|
// grpcConnection.Close()
|
|
|
|
|
|
|
|
|
return grpcConnection, nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return err |
|
|
|
|
|
|
|
|
func WithCachedGrpcClient(fn func(*grpc.ClientConn) error, address string, opts ...grpc.DialOption) error { |
|
|
|
|
|
|
|
|
|
|
|
grpcConnection, err := getOrCreateConnection(address, opts...) |
|
|
|
|
|
if err != nil { |
|
|
|
|
|
return fmt.Errorf("getOrCreateConnection %s: %v", address, err) |
|
|
|
|
|
} |
|
|
|
|
|
return fn(grpcConnection) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func ParseServerToGrpcAddress(server string) (serverGrpcAddress string, err error) { |
|
|
func ParseServerToGrpcAddress(server string) (serverGrpcAddress string, err error) { |
|
|