|
|
@ -14,8 +14,9 @@ import ( |
|
|
|
|
|
|
|
|
|
|
|
"github.com/bilibili/kratos/pkg/log" |
|
|
|
"github.com/bilibili/kratos/pkg/log" |
|
|
|
"github.com/bilibili/kratos/pkg/naming" |
|
|
|
"github.com/bilibili/kratos/pkg/naming" |
|
|
|
"github.com/coreos/etcd/clientv3" |
|
|
|
"go.etcd.io/etcd/clientv3" |
|
|
|
"github.com/coreos/etcd/mvcc/mvccpb" |
|
|
|
"go.etcd.io/etcd/mvcc/mvccpb" |
|
|
|
|
|
|
|
"google.golang.org/grpc" |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
var ( |
|
|
|
var ( |
|
|
@ -23,7 +24,9 @@ var ( |
|
|
|
endpoints string |
|
|
|
endpoints string |
|
|
|
etcdPrefix string |
|
|
|
etcdPrefix string |
|
|
|
|
|
|
|
|
|
|
|
RegisterTTL = 30 |
|
|
|
//Time units is second
|
|
|
|
|
|
|
|
registerTTL = 90 |
|
|
|
|
|
|
|
defaultDialTimeout = 30 |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
var ( |
|
|
|
var ( |
|
|
@ -96,7 +99,8 @@ func New(c *clientv3.Config) (e *EtcdBuilder, err error) { |
|
|
|
} |
|
|
|
} |
|
|
|
c = &clientv3.Config{ |
|
|
|
c = &clientv3.Config{ |
|
|
|
Endpoints: strings.Split(endpoints, ","), |
|
|
|
Endpoints: strings.Split(endpoints, ","), |
|
|
|
DialTimeout: time.Second * 30, |
|
|
|
DialTimeout: time.Second * time.Duration(defaultDialTimeout), |
|
|
|
|
|
|
|
DialOptions: []grpc.DialOption{grpc.WithBlock()}, |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
cli, err := clientv3.New(*c) |
|
|
|
cli, err := clientv3.New(*c) |
|
|
@ -179,8 +183,8 @@ func (e *EtcdBuilder) Register(ctx context.Context, ins *naming.Instance) (cance |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
go func() { |
|
|
|
go func() { |
|
|
|
//提前2秒续约 避免续约操作缓慢时租约过期
|
|
|
|
|
|
|
|
ticker := time.NewTicker(time.Duration(RegisterTTL-2) * time.Second) |
|
|
|
ticker := time.NewTicker(time.Duration(registerTTL/3) * time.Second) |
|
|
|
defer ticker.Stop() |
|
|
|
defer ticker.Stop() |
|
|
|
for { |
|
|
|
for { |
|
|
|
select { |
|
|
|
select { |
|
|
@ -201,9 +205,9 @@ func (e *EtcdBuilder) register(ctx context.Context, ins *naming.Instance) (err e |
|
|
|
prefix := e.keyPrefix(ins) |
|
|
|
prefix := e.keyPrefix(ins) |
|
|
|
val, _ := json.Marshal(ins) |
|
|
|
val, _ := json.Marshal(ins) |
|
|
|
|
|
|
|
|
|
|
|
ttlResp, err := e.cli.Grant(context.TODO(), int64(RegisterTTL)) |
|
|
|
ttlResp, err := e.cli.Grant(context.TODO(), int64(registerTTL)) |
|
|
|
if err != nil { |
|
|
|
if err != nil { |
|
|
|
log.Error("etcd: register client.Grant(%v) error(%v)", RegisterTTL, err) |
|
|
|
log.Error("etcd: register client.Grant(%v) error(%v)", registerTTL, err) |
|
|
|
return err |
|
|
|
return err |
|
|
|
} |
|
|
|
} |
|
|
|
_, err = e.cli.Put(ctx, prefix, string(val), clientv3.WithLease(ttlResp.ID)) |
|
|
|
_, err = e.cli.Put(ctx, prefix, string(val), clientv3.WithLease(ttlResp.ID)) |
|
|
|