Merge pull request #2882 from wpaulino/sync-manager-stale-syncer

discovery: only replace stale active syncer if disconnected
This commit is contained in:
Olaoluwa Osuntokun 2019-04-03 20:47:12 -07:00 committed by GitHub
commit 3a19afe46d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -286,6 +286,13 @@ func (m *SyncManager) roundRobinHandler() {
current = m.nextPendingActiveSyncer() current = m.nextPendingActiveSyncer()
m.Unlock() m.Unlock()
for current != nil { for current != nil {
// Ensure we properly handle a shutdown signal.
select {
case <-m.quit:
return
default:
}
// We'll avoid performing the transition with the lock // We'll avoid performing the transition with the lock
// as it can potentially stall the SyncManager due to // as it can potentially stall the SyncManager due to
// the syncTransitionTimeout. // the syncTransitionTimeout.
@ -353,19 +360,20 @@ func (m *SyncManager) roundRobinHandler() {
// the set of inactive syncers. // the set of inactive syncers.
if staleActiveSyncer.transitioned { if staleActiveSyncer.transitioned {
m.inactiveSyncers[s.cfg.peerPub] = s m.inactiveSyncers[s.cfg.peerPub] = s
} else {
// Otherwise, since the peer is disconnecting,
// we'll attempt to find a passive syncer that
// can replace it.
newActiveSyncer := m.chooseRandomSyncer(nil, false)
if newActiveSyncer != nil {
m.queueActiveSyncer(newActiveSyncer)
}
} }
// Remove the internal active syncer references for this // Remove the internal active syncer references for this
// peer. // peer.
delete(m.pendingActiveSyncers, s.cfg.peerPub) delete(m.pendingActiveSyncers, s.cfg.peerPub)
delete(m.activeSyncers, s.cfg.peerPub) delete(m.activeSyncers, s.cfg.peerPub)
// We'll then attempt to find a passive syncer that can
// replace the stale active syncer.
newActiveSyncer := m.chooseRandomSyncer(nil, false)
if newActiveSyncer != nil {
m.queueActiveSyncer(newActiveSyncer)
}
m.Unlock() m.Unlock()
// Signal to the caller that they can now proceed since // Signal to the caller that they can now proceed since
@ -530,6 +538,13 @@ func (m *SyncManager) forceHistoricalSync() {
candidatesChosen := make(map[routing.Vertex]struct{}) candidatesChosen := make(map[routing.Vertex]struct{})
s := m.chooseRandomSyncer(candidatesChosen, true) s := m.chooseRandomSyncer(candidatesChosen, true)
for s != nil { for s != nil {
// Ensure we properly handle a shutdown signal.
select {
case <-m.quit:
return
default:
}
// Blacklist the candidate to ensure it's not chosen again. // Blacklist the candidate to ensure it's not chosen again.
candidatesChosen[s.cfg.peerPub] = struct{}{} candidatesChosen[s.cfg.peerPub] = struct{}{}