From 6ecff26ec65ce1d559a3406b396b3190868b1961 Mon Sep 17 00:00:00 2001 From: DD Date: Sun, 12 Mar 2023 21:24:35 +0200 Subject: [PATCH] feat(WebSocketShard): heartbeat jitter (#9223) Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com> --- packages/ws/src/ws/WebSocketShard.ts | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/packages/ws/src/ws/WebSocketShard.ts b/packages/ws/src/ws/WebSocketShard.ts index 5330fa5ef919..4f0413d7c9de 100644 --- a/packages/ws/src/ws/WebSocketShard.ts +++ b/packages/ws/src/ws/WebSocketShard.ts @@ -567,7 +567,14 @@ export class WebSocketShard extends AsyncEventEmitter { case GatewayOpcodes.Hello: { this.emit(WebSocketShardEvents.Hello); - this.debug([`Starting to heartbeat every ${payload.d.heartbeat_interval}ms`]); + const jitter = Math.random(); + const firstWait = Math.floor(payload.d.heartbeat_interval * jitter); + this.debug([`Preparing first heartbeat of the connection with a jitter of ${jitter}; waiting ${firstWait}ms`]); + + await sleep(firstWait); + await this.heartbeat(); + + this.debug([`First heartbeat sent, starting to beat every ${payload.d.heartbeat_interval}ms`]); this.heartbeatInterval = setInterval(() => void this.heartbeat(), payload.d.heartbeat_interval); break; }