Skip to content

Commit

Permalink
eth/fetcher: if peers never respond, drop them
Browse files Browse the repository at this point in the history
  • Loading branch information
karalabe authored and unclezoro committed Sep 21, 2022
1 parent c54fd7f commit 211ab45
Showing 1 changed file with 31 additions and 8 deletions.
39 changes: 31 additions & 8 deletions eth/fetcher/block_fetcher.go
Original file line number Diff line number Diff line change
Expand Up @@ -508,10 +508,21 @@ func (f *BlockFetcher) loop() {
}
defer req.Close()

res := <-resCh
res.Done <- nil

f.FilterHeaders(peer, *res.Res.(*eth.BlockHeadersPacket), time.Now().Add(res.Time))
timeout := time.NewTimer(2 * fetchTimeout) // 2x leeway before dropping the peer
defer timeout.Stop()

select {
case res := <-resCh:
res.Done <- nil
f.FilterHeaders(peer, *res.Res.(*eth.BlockHeadersPacket), time.Now().Add(res.Time))

case <-timeout.C:
// The peer didn't respond in time. The request
// was already rescheduled at this point, we were
// waiting for a catchup. With an unresponsive
// peer however, it's a protocol violation.
f.dropPeer(peer)
}
}(hash)
}
}(peer)
Expand Down Expand Up @@ -554,11 +565,23 @@ func (f *BlockFetcher) loop() {
}
defer req.Close()

res := <-resCh
res.Done <- nil
timeout := time.NewTimer(2 * fetchTimeout) // 2x leeway before dropping the peer
defer timeout.Stop()

select {
case res := <-resCh:
res.Done <- nil

txs, uncles := res.Res.(*eth.BlockBodiesPacket).Unpack()
f.FilterBodies(peer, txs, uncles, time.Now())
txs, uncles := res.Res.(*eth.BlockBodiesPacket).Unpack()
f.FilterBodies(peer, txs, uncles, time.Now())

case <-timeout.C:
// The peer didn't respond in time. The request
// was already rescheduled at this point, we were
// waiting for a catchup. With an unresponsive
// peer however, it's a protocol violation.
f.dropPeer(peer)
}
}(peer, hashes)
}
// Schedule the next fetch if blocks are still pending
Expand Down

0 comments on commit 211ab45

Please sign in to comment.