From ddfe4a804d79e7788ab136290e609f91cf68423f Mon Sep 17 00:00:00 2001 From: Luigi Pinca Date: Sat, 18 May 2024 17:11:07 +0200 Subject: [PATCH] [perf] Reduce the amount of `crypto.randomFillSync()` calls Use a pool of random bytes to reduce the amount of `crypto.randomFillSync()` calls. Refs: https://github.com/nodejs/undici/pull/3204 --- lib/sender.js | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/lib/sender.js b/lib/sender.js index 1ed04b027..5ea2986ee 100644 --- a/lib/sender.js +++ b/lib/sender.js @@ -12,6 +12,9 @@ const { mask: applyMask, toBuffer } = require('./buffer-util'); const kByteLength = Symbol('kByteLength'); const maskBuffer = Buffer.alloc(4); +const RANDOM_POOL_SIZE = 8 * 1024; +let randomPool; +let randomPoolPointer = RANDOM_POOL_SIZE; /** * HyBi Sender implementation. @@ -76,7 +79,19 @@ class Sender { if (options.generateMask) { options.generateMask(mask); } else { - randomFillSync(mask, 0, 4); + if (randomPoolPointer === RANDOM_POOL_SIZE) { + if (randomPool === undefined) { + randomPool = Buffer.alloc(RANDOM_POOL_SIZE); + } + + randomFillSync(randomPool, 0, RANDOM_POOL_SIZE); + randomPoolPointer = 0; + } + + mask[0] = randomPool[randomPoolPointer++]; + mask[1] = randomPool[randomPoolPointer++]; + mask[2] = randomPool[randomPoolPointer++]; + mask[3] = randomPool[randomPoolPointer++]; } skipMasking = (mask[0] | mask[1] | mask[2] | mask[3]) === 0;