|
|
|
@ -1,6 +1,7 @@
|
|
|
|
|
package getcdv3
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"Open_IM/pkg/common/log"
|
|
|
|
|
"context"
|
|
|
|
|
"fmt"
|
|
|
|
|
"strings"
|
|
|
|
@ -43,6 +44,12 @@ func NewResolver(schema, etcdAddr, serviceName string) (*Resolver, error) {
|
|
|
|
|
r.schema = schema
|
|
|
|
|
r.etcdAddr = etcdAddr
|
|
|
|
|
resolver.Register(&r)
|
|
|
|
|
//
|
|
|
|
|
//ctx, _ := context.WithTimeout(context.Background(), time.Second*5)
|
|
|
|
|
//conn, err := grpc.DialContext(ctx, GetPrefix(schema, serviceName),
|
|
|
|
|
// grpc.WithDefaultServiceConfig(fmt.Sprintf(`{"LoadBalancingPolicy": "%s"}`, roundrobin.Name)),
|
|
|
|
|
// grpc.WithInsecure())
|
|
|
|
|
log.Debug("", "etcd key ", GetPrefix(schema, serviceName), "value ", *r.grpcClientConn)
|
|
|
|
|
|
|
|
|
|
conn, err := grpc.Dial(
|
|
|
|
|
GetPrefix(schema, serviceName),
|
|
|
|
@ -67,6 +74,7 @@ func GetConn(schema, etcdaddr, serviceName string) *grpc.ClientConn {
|
|
|
|
|
r, ok := nameResolver[schema+serviceName]
|
|
|
|
|
rwNameResolverMutex.RUnlock()
|
|
|
|
|
if ok {
|
|
|
|
|
log.Debug("", "etcd key ", schema+serviceName, "value ", *r.grpcClientConn, *r)
|
|
|
|
|
return r.grpcClientConn
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -74,15 +82,18 @@ func GetConn(schema, etcdaddr, serviceName string) *grpc.ClientConn {
|
|
|
|
|
r, ok = nameResolver[schema+serviceName]
|
|
|
|
|
if ok {
|
|
|
|
|
rwNameResolverMutex.Unlock()
|
|
|
|
|
log.Debug("", "etcd key ", schema+serviceName, "value ", *r.grpcClientConn, *r)
|
|
|
|
|
return r.grpcClientConn
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
r, err := NewResolver(schema, etcdaddr, serviceName)
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Error("", "etcd failed ", schema, etcdaddr, serviceName)
|
|
|
|
|
rwNameResolverMutex.Unlock()
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
log.Debug("", "etcd key ", schema+serviceName, "value ", *r.grpcClientConn, *r)
|
|
|
|
|
nameResolver[schema+serviceName] = r
|
|
|
|
|
rwNameResolverMutex.Unlock()
|
|
|
|
|
return r.grpcClientConn
|
|
|
|
|