shorten idle timeout

This commit is contained in:
Jacek Sieka 2021-01-13 16:33:36 +01:00 committed by zah
parent 76f15302a7
commit c0e11cfba6

View File

@ -468,10 +468,11 @@ proc runQueueProcessingLoop*(self: ref Eth2Processor) {.async.} =
# on the same thread, we need to make sure that there is steady progress # on the same thread, we need to make sure that there is steady progress
# on the networking side or we get long lockups that lead to timeouts. # on the networking side or we get long lockups that lead to timeouts.
# #
# We cap waiting for an idle slot to 1 second in case there's a lot of # We cap waiting for an idle slot in case there's a lot of network traffic
# network traffic taking up all CPU - we don't want to _completely_ stop # taking up all CPU - we don't want to _completely_ stop processing blocks
# processing blocks in this case (attestations will get dropped) # in this case (attestations will get dropped) - doing so also allows us
discard await idleAsync().withTimeout(1.seconds) # to benefit from more batching / larger network reads when under load.
discard await idleAsync().withTimeout(100.milliseconds)
# Avoid one more `await` when there's work to do # Avoid one more `await` when there's work to do
if not (blockFut.finished or aggregateFut.finished or attestationFut.finished): if not (blockFut.finished or aggregateFut.finished or attestationFut.finished):