From 51391aa2ac5bc209a40f0a35b22c5d6db9d5f1ee Mon Sep 17 00:00:00 2001 From: gabrielmer <101006718+gabrielmer@users.noreply.github.com> Date: Thu, 12 Sep 2024 22:49:47 +0200 Subject: [PATCH] adding a dynamic sleep interval in the connectivity loop (#3031) --- waku/node/peer_manager/peer_manager.nim | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/waku/node/peer_manager/peer_manager.nim b/waku/node/peer_manager/peer_manager.nim index f44c0c21e4..12c6a084f7 100644 --- a/waku/node/peer_manager/peer_manager.nim +++ b/waku/node/peer_manager/peer_manager.nim @@ -965,7 +965,21 @@ proc relayConnectivityLoop*(pm: PeerManager) {.async.} = await pm.manageRelayPeers() else: await pm.connectToRelayPeers() - await sleepAsync(ConnectivityLoopInterval) + let + (inRelayPeers, outRelayPeers) = pm.connectedPeers(WakuRelayCodec) + excessInConns = max(inRelayPeers.len - pm.inRelayPeersTarget, 0) + + # One minus the percentage of excess connections relative to the target, limited to 100% + # We calculate one minus this percentage because we want the factor to be inversely proportional to the number of excess peers + inFactor = 1 - min(excessInConns / pm.inRelayPeersTarget, 1) + # Percentage of out relay peers relative to the target + outFactor = min(outRelayPeers.len / pm.outRelayPeersTarget, 1) + factor = min(outFactor, inFactor) + dynamicSleepInterval = + chronos.seconds(int(float(ConnectivityLoopInterval.seconds()) * factor)) + + # Shorten the connectivity loop interval dynamically based on percentage of peers to fill or connections to prune + await sleepAsync(dynamicSleepInterval) proc logAndMetrics(pm: PeerManager) {.async.} = heartbeat "Scheduling log and metrics run", LogAndMetricsInterval: