eth/downloader: drop beacon head updates if the syncer is restarting (#27397)
* eth/downloader: drop beacon head updates if the syncer is restarting * eth/donwloader: v2 of the goroutine spike preventer
This commit is contained in:
parent
c7c84ca16c
commit
a7b2106edf
|
@ -367,13 +367,31 @@ func (s *skeleton) sync(head *types.Header) (*types.Header, error) {
|
||||||
s.filler.resume()
|
s.filler.resume()
|
||||||
}
|
}
|
||||||
defer func() {
|
defer func() {
|
||||||
if filled := s.filler.suspend(); filled != nil {
|
// The filler needs to be suspended, but since it can block for a while
|
||||||
// If something was filled, try to delete stale sync helpers. If
|
// when there are many blocks queued up for full-sync importing, run it
|
||||||
// unsuccessful, warn the user, but not much else we can do (it's
|
// on a separate goroutine and consume head messages that need instant
|
||||||
// a programming error, just let users report an issue and don't
|
// replies.
|
||||||
// choke in the meantime).
|
done := make(chan struct{})
|
||||||
if err := s.cleanStales(filled); err != nil {
|
go func() {
|
||||||
log.Error("Failed to clean stale beacon headers", "err", err)
|
defer close(done)
|
||||||
|
if filled := s.filler.suspend(); filled != nil {
|
||||||
|
// If something was filled, try to delete stale sync helpers. If
|
||||||
|
// unsuccessful, warn the user, but not much else we can do (it's
|
||||||
|
// a programming error, just let users report an issue and don't
|
||||||
|
// choke in the meantime).
|
||||||
|
if err := s.cleanStales(filled); err != nil {
|
||||||
|
log.Error("Failed to clean stale beacon headers", "err", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
// Wait for the suspend to finish, consuming head events in the meantime
|
||||||
|
// and dropping them on the floor.
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case <-done:
|
||||||
|
return
|
||||||
|
case event := <-s.headEvents:
|
||||||
|
event.errc <- errors.New("beacon syncer reorging")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
Loading…
Reference in New Issue