X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Futils.ts;h=f7aab63746e274b328d606fb3659a5353e796132;hb=5b5321fd0b3ef10dd12b9aa21bf3ca9fa3970e76;hp=8e84e9474c8a91d1adceb740e5c5ff21292faa02;hpb=69bba5e2db6d6895a327efaa815559d58a836c33;p=poolifier.git diff --git a/src/utils.ts b/src/utils.ts index 8e84e947..f7aab637 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -1,5 +1,5 @@ import * as os from 'node:os' -import { getRandomValues } from 'node:crypto' +import { getRandomValues, randomInt } from 'node:crypto' import { Worker as ClusterWorker } from 'node:cluster' import { Worker as ThreadWorker } from 'node:worker_threads' import { cpus } from 'node:os' @@ -304,8 +304,9 @@ export const buildInternalWorkerChoiceStrategyOptions = ( const getDefaultWeights = ( poolMaxSize: number, - defaultWorkerWeight: number = getDefaultWorkerWeight() + defaultWorkerWeight?: number ): Record => { + defaultWorkerWeight = defaultWorkerWeight ?? getDefaultWorkerWeight() const weights: Record = {} for (let workerNodeKey = 0; workerNodeKey < poolMaxSize; workerNodeKey++) { weights[workerNodeKey] = defaultWorkerWeight @@ -314,8 +315,14 @@ const getDefaultWeights = ( } const getDefaultWorkerWeight = (): number => { + const cpuSpeed = randomInt(500, 2500) let cpusCycleTimeWeight = 0 for (const cpu of cpus()) { + if (cpu.speed == null || cpu.speed === 0) { + cpu.speed = + cpus().find(cpu => cpu.speed != null && cpu.speed !== 0)?.speed ?? + cpuSpeed + } // CPU estimated cycle time const numberOfDigits = cpu.speed.toString().length - 1 const cpuCycleTime = 1 / (cpu.speed / Math.pow(10, numberOfDigits))