Skip to content

Commit

Permalink
register immediately
Browse files Browse the repository at this point in the history
Signed-off-by: Ryan Leung <[email protected]>
  • Loading branch information
rleungx committed Oct 31, 2024
1 parent 75adf40 commit 3c5c787
Showing 1 changed file with 33 additions and 23 deletions.
56 changes: 33 additions & 23 deletions pkg/tso/global_allocator.go
Original file line number Diff line number Diff line change
Expand Up @@ -775,38 +775,48 @@ func (gta *GlobalTSOAllocator) deregisterAllocator() error {
}

func (gta *GlobalTSOAllocator) tryRegister() <-chan *clientv3.LeaseKeepAliveResponse {
// register immediately
kresp, needRetry := gta.register()
if !needRetry {
return kresp
}
ticker := time.NewTicker(100 * time.Millisecond)
defer ticker.Stop()
outerLoop:
for {
select {
case <-gta.ctx.Done():
return nil
case <-ticker.C:
ctx, cancel := context.WithTimeout(gta.ctx, time.Duration(3)*time.Second)
resp, err := gta.am.etcdClient.Get(ctx, gta.am.allocatorKeyPrefix, clientv3.WithPrefix())
cancel()
if err != nil {
continue
}
// wait for the previous allocator with different mode to be deregistered
if len(resp.Kvs) > 0 {
for _, kv := range resp.Kvs {
key := string(kv.Key)
if !strings.Contains(key, gta.am.allocatorKeyPrefix) {
continue outerLoop
}
}
if kresp, needRetry := gta.register(); !needRetry {
return kresp
}
id, err := gta.txnWithTTL(gta.am.allocatorKey, "")
if err != nil {
continue
}
kresp, err := gta.am.etcdClient.KeepAlive(gta.ctx, id)
if err != nil {
continue
}
}
}

func (gta *GlobalTSOAllocator) register() (<-chan *clientv3.LeaseKeepAliveResponse, bool) {
ctx, cancel := context.WithTimeout(gta.ctx, time.Duration(3)*time.Second)
resp, err := gta.am.etcdClient.Get(ctx, gta.am.allocatorKeyPrefix, clientv3.WithPrefix())
cancel()
if err != nil {
return nil, true
}
// wait for the previous allocator with different mode to be deregistered
if len(resp.Kvs) > 0 {
for _, kv := range resp.Kvs {
key := string(kv.Key)
if !strings.Contains(key, gta.am.allocatorKeyPrefix) {
return nil, true
}
return kresp
}
}
id, err := gta.txnWithTTL(gta.am.allocatorKey, "")
if err != nil {
return nil, true
}
kresp, err := gta.am.etcdClient.KeepAlive(gta.ctx, id)
if err != nil {
return nil, true
}
return kresp, false
}

0 comments on commit 3c5c787

Please sign in to comment.