X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fpools%2Fabstract-pool.ts;h=81012fa0b4f736559fca73eb395bf7c622bce48a;hb=09a6305fb250c17cb2565f8cbe3d9afbb33f307c;hp=e396744603eed1011518cbb3f62b59bb3cedd305;hpb=0567595a23237d7b0e4bc0ec70c8e313eb71bb10;p=poolifier.git diff --git a/src/pools/abstract-pool.ts b/src/pools/abstract-pool.ts index e3967446..81012fa0 100644 --- a/src/pools/abstract-pool.ts +++ b/src/pools/abstract-pool.ts @@ -419,18 +419,7 @@ export abstract class AbstractPool< workerNodeKey: number, task: Task ): void { - const workerTasksUsage = this.workerNodes[workerNodeKey].tasksUsage - ++workerTasksUsage.running - if (this.workerChoiceStrategyContext.getRequiredStatistics().waitTime) { - const waitTime = performance.now() - (task.submissionTimestamp ?? 0) - workerTasksUsage.waitTime += waitTime - if ( - this.workerChoiceStrategyContext.getRequiredStatistics().medWaitTime - ) { - workerTasksUsage.waitTimeHistory.push(waitTime) - workerTasksUsage.medWaitTime = median(workerTasksUsage.waitTimeHistory) - } - } + ++this.workerNodes[workerNodeKey].tasksUsage.running } /** @@ -468,13 +457,22 @@ export abstract class AbstractPool< workerTasksUsage.medRunTime = median(workerTasksUsage.runTimeHistory) } } - if ( - this.workerChoiceStrategyContext.getRequiredStatistics().waitTime && - this.workerChoiceStrategyContext.getRequiredStatistics().avgWaitTime && - workerTasksUsage.run !== 0 - ) { - workerTasksUsage.avgWaitTime = - workerTasksUsage.waitTime / workerTasksUsage.run + if (this.workerChoiceStrategyContext.getRequiredStatistics().waitTime) { + workerTasksUsage.waitTime += message.waitTime ?? 0 + if ( + this.workerChoiceStrategyContext.getRequiredStatistics().avgWaitTime && + workerTasksUsage.run !== 0 + ) { + workerTasksUsage.avgWaitTime = + workerTasksUsage.waitTime / workerTasksUsage.run + } + if ( + this.workerChoiceStrategyContext.getRequiredStatistics().medWaitTime && + message.waitTime != null + ) { + workerTasksUsage.waitTimeHistory.push(message.waitTime) + workerTasksUsage.medWaitTime = median(workerTasksUsage.waitTimeHistory) + } } }