repositories
/
poolifier.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
build: disable esModuleInterop from TS configuration
[poolifier.git]
/
src
/
pools
/
selection-strategies
/
abstract-worker-choice-strategy.ts
diff --git
a/src/pools/selection-strategies/abstract-worker-choice-strategy.ts
b/src/pools/selection-strategies/abstract-worker-choice-strategy.ts
index 476c58bc8bcf45f69450adb196e8886abe6f3b88..cd969ccd69d99fed15d08e9cca74450d424df5aa 100644
(file)
--- a/
src/pools/selection-strategies/abstract-worker-choice-strategy.ts
+++ b/
src/pools/selection-strategies/abstract-worker-choice-strategy.ts
@@
-1,5
+1,8
@@
import { cpus } from 'node:os'
import { cpus } from 'node:os'
-import { DEFAULT_WORKER_CHOICE_STRATEGY_OPTIONS } from '../../utils'
+import {
+ DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS,
+ DEFAULT_WORKER_CHOICE_STRATEGY_OPTIONS
+} from '../../utils'
import type { IPool } from '../pool'
import type { IWorker } from '../worker'
import type {
import type { IPool } from '../pool'
import type { IWorker } from '../worker'
import type {
@@
-13,8
+16,8
@@
import type {
* Worker choice strategy abstract base class.
*
* @typeParam Worker - Type of worker which manages the strategy.
* Worker choice strategy abstract base class.
*
* @typeParam Worker - Type of worker which manages the strategy.
- * @typeParam Data - Type of data sent to the worker. This can only be s
erializ
able data.
- * @typeParam Response - Type of execution response. This can only be s
erializ
able data.
+ * @typeParam Data - Type of data sent to the worker. This can only be s
tructured-clone
able data.
+ * @typeParam Response - Type of execution response. This can only be s
tructured-clone
able data.
*/
export abstract class AbstractWorkerChoiceStrategy<
Worker extends IWorker,
*/
export abstract class AbstractWorkerChoiceStrategy<
Worker extends IWorker,
@@
-38,21
+41,9
@@
export abstract class AbstractWorkerChoiceStrategy<
/** @inheritDoc */
public readonly taskStatisticsRequirements: TaskStatisticsRequirements = {
/** @inheritDoc */
public readonly taskStatisticsRequirements: TaskStatisticsRequirements = {
- runTime: {
- aggregate: false,
- average: false,
- median: false
- },
- waitTime: {
- aggregate: false,
- average: false,
- median: false
- },
- elu: {
- aggregate: false,
- average: false,
- median: false
- }
+ runTime: DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS,
+ waitTime: DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS,
+ elu: DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS
}
/**
}
/**
@@
-133,9
+124,8
@@
export abstract class AbstractWorkerChoiceStrategy<
/** @inheritDoc */
public setOptions (opts: WorkerChoiceStrategyOptions): void {
/** @inheritDoc */
public setOptions (opts: WorkerChoiceStrategyOptions): void {
- opts = opts ?? DEFAULT_WORKER_CHOICE_STRATEGY_OPTIONS
- this.setTaskStatisticsRequirements(opts)
- this.opts = opts
+ this.opts = opts ?? DEFAULT_WORKER_CHOICE_STRATEGY_OPTIONS
+ this.setTaskStatisticsRequirements(this.opts)
}
// /**
}
// /**
@@
-162,8
+152,8
@@
export abstract class AbstractWorkerChoiceStrategy<
*/
protected getWorkerTaskRunTime (workerNodeKey: number): number {
return this.taskStatisticsRequirements.runTime.median
*/
protected getWorkerTaskRunTime (workerNodeKey: number): number {
return this.taskStatisticsRequirements.runTime.median
- ? this.pool.workerNodes[workerNodeKey].
workerU
sage.runTime.median
- : this.pool.workerNodes[workerNodeKey].
workerU
sage.runTime.average
+ ? this.pool.workerNodes[workerNodeKey].
u
sage.runTime.median
+ : this.pool.workerNodes[workerNodeKey].
u
sage.runTime.average
}
/**
}
/**
@@
-176,8
+166,8
@@
export abstract class AbstractWorkerChoiceStrategy<
*/
protected getWorkerTaskWaitTime (workerNodeKey: number): number {
return this.taskStatisticsRequirements.waitTime.median
*/
protected getWorkerTaskWaitTime (workerNodeKey: number): number {
return this.taskStatisticsRequirements.waitTime.median
- ? this.pool.workerNodes[workerNodeKey].
workerU
sage.waitTime.median
- : this.pool.workerNodes[workerNodeKey].
workerU
sage.waitTime.average
+ ? this.pool.workerNodes[workerNodeKey].
u
sage.waitTime.median
+ : this.pool.workerNodes[workerNodeKey].
u
sage.waitTime.average
}
/**
}
/**
@@
-190,8
+180,8
@@
export abstract class AbstractWorkerChoiceStrategy<
*/
protected getWorkerTaskElu (workerNodeKey: number): number {
return this.taskStatisticsRequirements.elu.median
*/
protected getWorkerTaskElu (workerNodeKey: number): number {
return this.taskStatisticsRequirements.elu.median
- ? this.pool.workerNodes[workerNodeKey].
workerU
sage.elu.active.median
- : this.pool.workerNodes[workerNodeKey].
workerU
sage.elu.active.average
+ ? this.pool.workerNodes[workerNodeKey].
u
sage.elu.active.median
+ : this.pool.workerNodes[workerNodeKey].
u
sage.elu.active.average
}
protected computeDefaultWorkerWeight (): number {
}
protected computeDefaultWorkerWeight (): number {
@@
-216,7
+206,7
@@
export abstract class AbstractWorkerChoiceStrategy<
// */
// private findFirstFreeWorkerNodeKey (): number {
// return this.pool.workerNodes.findIndex(workerNode => {
// */
// private findFirstFreeWorkerNodeKey (): number {
// return this.pool.workerNodes.findIndex(workerNode => {
- // return workerNode.
workerU
sage.tasks.executing === 0
+ // return workerNode.
u
sage.tasks.executing === 0
// })
// }
// })
// }
@@
-231,17
+221,15
@@
export abstract class AbstractWorkerChoiceStrategy<
// */
// private findLastFreeWorkerNodeKey (): number {
// // It requires node >= 18.0.0:
// */
// private findLastFreeWorkerNodeKey (): number {
// // It requires node >= 18.0.0:
- // // return this.workerNodes.findLastIndex(workerNode => {
- // // return workerNode.
workerU
sage.tasks.executing === 0
+ // // return this.
pool.
workerNodes.findLastIndex(workerNode => {
+ // // return workerNode.
u
sage.tasks.executing === 0
// // })
// for (
// let workerNodeKey = this.pool.workerNodes.length - 1;
// workerNodeKey >= 0;
// workerNodeKey--
// ) {
// // })
// for (
// let workerNodeKey = this.pool.workerNodes.length - 1;
// workerNodeKey >= 0;
// workerNodeKey--
// ) {
- // if (
- // this.pool.workerNodes[workerNodeKey].workerUsage.tasks.executing === 0
- // ) {
+ // if (this.pool.workerNodes[workerNodeKey].usage.tasks.executing === 0) {
// return workerNodeKey
// }
// }
// return workerNodeKey
// }
// }