Merge pull request #7335 from heyitsanthony/leadership-kick

grpcproxy: support forcing leader as available
This commit is contained in:
Anthony Romano 2017-02-16 09:40:08 -08:00 committed by GitHub
commit 49a12371c1

View File

@ -63,24 +63,44 @@ func (l *leader) recvLoop() {
wch := l.w.Watch(l.ctx, lostLeaderKey, clientv3.WithRev(rev), clientv3.WithCreatedNotify())
cresp, ok := <-wch
if !ok {
l.loseLeader()
continue
}
if cresp.Err() != nil {
l.loseLeader()
if grpc.ErrorDesc(cresp.Err()) == grpc.ErrClientConnClosing.Error() {
close(l.disconnc)
return
}
continue
}
// leader is available
l.mu.Lock()
l.leaderc = make(chan struct{})
l.mu.Unlock()
l.gotLeader()
<-wch
l.loseLeader()
}
}
func (l *leader) loseLeader() {
l.mu.RLock()
defer l.mu.RUnlock()
select {
case <-l.leaderc:
default:
close(l.leaderc)
}
}
// gotLeader will force update the leadership status to having a leader.
func (l *leader) gotLeader() {
l.mu.Lock()
defer l.mu.Unlock()
select {
case <-l.leaderc:
l.leaderc = make(chan struct{})
default:
}
}
func (l *leader) disconnectNotify() <-chan struct{} { return l.disconnc }
func (l *leader) stopNotify() <-chan struct{} { return l.donec }