X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=docs%2Fclasses%2FAbstractPool.html;h=93ac3c6721bf8075a60f759af5c386f8884161ad;hb=b20bf19abbcc1fb78e71f843d6eb56ad8c4c630c;hp=260674bacd2c5c0cc33676692a6887a20754e108;hpb=a3294554408b42a4df2e37eb69f9c8a554a0c2f3;p=poolifier.git diff --git a/docs/classes/AbstractPool.html b/docs/classes/AbstractPool.html index 260674ba..93ac3c67 100644 --- a/docs/classes/AbstractPool.html +++ b/docs/classes/AbstractPool.html @@ -1,13 +1,13 @@ -AbstractPool | poolifier - v3.0.13

Class AbstractPool<Worker, Data, Response>Abstract

Base class that implements some shared logic for all poolifier pools.

+AbstractPool | poolifier - v3.1.12

Class AbstractPool<Worker, Data, Response>Abstract

Base class that implements some shared logic for all poolifier pools.

Type Parameters

  • Worker extends IWorker

    Type of worker which manages this pool.

  • Data = unknown

    Type of data sent to the worker. This can only be structured-cloneable data.

  • Response = unknown

    Type of execution response. This can only be structured-cloneable data.

    -

Hierarchy

Implements

  • IPool<Worker, Data, Response>

Constructors

Hierarchy

Implements

  • IPool<Worker, Data, Response>

Constructors

Properties

Accessors

busy full info -maxSize -minSize ready type utilization @@ -32,17 +30,19 @@ afterWorkerNodeSetup beforeTaskExecutionHook buildTasksQueueOptions -checkAndEmitDynamicWorkerCreationEvents +cannotStealTask +checkAndEmitDynamicWorkerCreationEvents checkAndEmitTaskExecutionEvents checkAndEmitTaskQueuingEvents checkMessageWorkerId -checkNumberOfWorkers +checkMinimumNumberOfWorkers checkPoolOptions +checkPoolType checkValidWorkerChoiceStrategyOptions chooseWorkerNode createAndSetupDynamicWorkerNode createAndSetupWorkerNode -createWorker +createWorkerNode deleteTaskFunctionWorkerUsages dequeueTask deregisterWorkerMessageListener @@ -56,10 +56,10 @@ flushTasksQueue flushTasksQueues getWorkerInfo -getWorkerNodeKeyByWorker getWorkerNodeKeyByWorkerId handleBackPressureEvent handleIdleWorkerNodeEvent +handleTask handleTaskExecutionResponse handleWorkerReadyResponse hasBackPressure @@ -68,6 +68,7 @@ initializeEventEmitter internalBusy isMain +isWorkerNodeBusy listTaskFunctionNames redistributeQueuedTasks registerOnceWorkerMessageListener @@ -76,7 +77,7 @@ removeWorkerNode resetTaskSequentiallyStolenStatisticsTaskFunctionWorkerUsage resetTaskSequentiallyStolenStatisticsWorkerUsage -sendKillMessageToWorker +sendKillMessageToWorker sendStartupMessageToWorker sendStatisticsMessageToWorker sendTaskFunctionOperationToWorker @@ -90,28 +91,25 @@ setWorkerChoiceStrategy setWorkerChoiceStrategyOptions setupHook -shallCreateDynamicWorker +shallCreateDynamicWorker shallExecuteTask shallUpdateTaskFunctionWorkerUsage start tasksQueueSize unsetTaskStealing unsetTasksStealingOnBackPressure -updateEluWorkerUsage -updateRunTimeWorkerUsage updateTaskSequentiallyStolenStatisticsTaskFunctionWorkerUsage updateTaskSequentiallyStolenStatisticsWorkerUsage -updateTaskStatisticsWorkerUsage updateTaskStolenStatisticsWorkerUsage -updateWaitTimeWorkerUsage workerMessageListener workerNodeStealTask -

Constructors

  • Constructs a new poolifier pool.

    -

    Type Parameters

    • Worker extends IWorker

    • Data = unknown

    • Response = unknown

    Parameters

    • numberOfWorkers: number

      Number of workers that this pool should manage.

      +

Constructors

  • Constructs a new poolifier pool.

    +

    Type Parameters

    • Worker extends IWorker

    • Data = unknown

    • Response = unknown

    Parameters

    • minimumNumberOfWorkers: number

      Minimum number of workers that this pool manages.

    • filePath: string

      Path to the worker file.

    • opts: PoolOptions<Worker>

      Options for the pool.

      -

    Returns AbstractPool<Worker, Data, Response>

Properties

destroying: boolean

Whether the pool is destroying or not.

-
emitter?: EventEmitterAsyncResource

Event emitter integrated with async resource on which events can be listened to. +

  • Optional maximumNumberOfWorkers: number

    Maximum number of workers that this pool manages.

    +
  • Returns AbstractPool<Worker, Data, Response>

    Properties

    destroying: boolean

    Whether the pool is destroying or not.

    +
    emitter?: EventEmitterAsyncResource

    Event emitter integrated with async resource on which events can be listened to. The async tracking tooling identifier is poolifier:<PoolType>-<WorkerType>-pool.

    Events that can currently be listened to:

      @@ -123,147 +121,143 @@ The async tracking tooling identifier is poolifier:<PoolType>-<Wo
    • 'taskError': Emitted when an error occurs while executing a task.
    • 'backPressure': Emitted when all worker nodes have back pressure (i.e. their tasks queue is full: queue size >= maximum queue size).
    -
    filePath: string

    Path to the worker file.

    -
    max?: number

    Dynamic pool maximum size property placeholder.

    -
    numberOfWorkers: number

    Number of workers that this pool should manage.

    -
    opts: PoolOptions<Worker>

    Options for the pool.

    -
    promiseResponseMap: Map<string, PromiseResponseWrapper<Response>> = ...

    The task execution response promise map:

    +
    filePath: string

    Path to the worker file.

    +
    maximumNumberOfWorkers?: number

    Maximum number of workers that this pool manages.

    +
    minimumNumberOfWorkers: number

    Minimum number of workers that this pool manages.

    +
    opts: PoolOptions<Worker>

    Options for the pool.

    +
    promiseResponseMap: Map<string, PromiseResponseWrapper<Response>> = ...

    The task execution response promise map:

    • key: The message id of each submitted task.
    • value: An object that contains the worker, the execution response promise resolve and reject callbacks.

    When we receive a message from the worker, we get a map entry with the promise resolve/reject bound to the message id.

    -
    readyEventEmitted: boolean

    Whether the pool ready event has been emitted or not.

    -
    startTimestamp: number

    The start timestamp of the pool.

    -
    started: boolean

    Whether the pool is started or not.

    -
    starting: boolean

    Whether the pool is starting or not.

    -
    taskFunctions: Map<string, TaskFunction<Data, Response>>

    The task functions added at runtime map:

    +
    readyEventEmitted: boolean

    Whether the pool ready event has been emitted or not.

    +
    startTimestamp: number

    The start timestamp of the pool.

    +
    started: boolean

    Whether the pool is started or not.

    +
    starting: boolean

    Whether the pool is starting or not.

    +
    taskFunctions: Map<string, TaskFunction<Data, Response>>

    The task functions added at runtime map:

    • key: The task function name.
    • value: The task function itself.
    -
    workerChoiceStrategyContext: WorkerChoiceStrategyContext<Worker, Data, Response>

    Worker choice strategy context referencing a worker choice algorithm implementation.

    -
    workerNodes: IWorkerNode<Worker, Data>[] = []

    Pool worker nodes.

    -

    Accessors

    workerChoiceStrategyContext: WorkerChoiceStrategyContext<Worker, Data, Response>

    Worker choice strategy context referencing a worker choice algorithm implementation.

    +
    workerNodes: IWorkerNode<Worker, Data>[] = []

    Pool worker nodes.

    +

    Accessors

    • get type(): "fixed" | "dynamic"
    • The pool type.

      If it is 'dynamic', it provides the max property.

      -

      Returns "fixed" | "dynamic"

    Methods

    Methods

    • Hook executed after the worker task execution. Can be overridden.

      Parameters

      • workerNodeKey: number

        The worker node key.

      • message: MessageValue<Response, unknown>

        The received message.

        -

      Returns void

    • Method hooked up after a worker node has been newly created. +

    Returns void

    • Method hooked up after a worker node has been newly created. Can be overridden.

      Parameters

      • workerNodeKey: number

        The newly created worker node key.

        -

      Returns void

    • Hook executed before the worker task execution. +

    Returns void

    Returns void

    Returns void

    Returns Promise<void>

    Returns void

    Returns void

    Returns void

    Returns void

    Returns void

    Returns void

    Returns void

    Returns void

    Returns void

    Returns void

    Generated using TypeDoc

    \ No newline at end of file +

    Generated using TypeDoc

    \ No newline at end of file