X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=docs%2Fclasses%2FDynamicThreadPool.html;h=f7d0f636121ec2272935ac901affaa0dcc106a59;hb=0cf6d1374ad842cc31aca1a8ddaa1bc5a9b9302b;hp=af5ecbce6469b1600298b58e061f53ddc575d1c7;hpb=aec509b85e7d73e9883c8885e27fc4e34fdaef1e;p=poolifier.git diff --git a/docs/classes/DynamicThreadPool.html b/docs/classes/DynamicThreadPool.html index af5ecbce..f7d0f636 100644 --- a/docs/classes/DynamicThreadPool.html +++ b/docs/classes/DynamicThreadPool.html @@ -1,13 +1,13 @@ -
Type of data sent to the worker. This can only be serializable data.
-Type of data sent to the worker. This can only be structured-cloneable data.
+Type of response of execution. This can only be serializable data.
-Type of execution response. This can only be structured-cloneable data.
+Constructs a new poolifier dynamic thread pool.
Minimum number of threads which are always active.
-Maximum number of threads that can be created by this pool.
-Path to an implementation of a ThreadWorker
file, which can be relative or absolute.
Options for this dynamic thread pool.
-Optional
Readonly
emitterEmitter on which events can be listened to.
+Optional
emitterEvent 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:
'full'
: Emitted when the pool is dynamic and full.'busy'
: Emitted when the pool is busy.'ready'
: Emitted when the number of workers created in the pool has reached the minimum size expected and are ready.'busy'
: Emitted when the number of workers created in the pool has reached the maximum size expected and are executing concurrently their tasks quota.'full'
: Emitted when the pool is dynamic and the number of workers created has reached the maximum size expected.'destroy'
: Emitted when the pool is destroyed.'error'
: Emitted when an uncaught error occurs.'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).Readonly
filePath to the worker-file.
-Protected
Readonly
filePath to the worker file.
+Readonly
maxProtected
Readonly
maxMaximum number of threads that can be created by this pool.
-Readonly
numberProtected
Readonly
numberNumber of workers that this pool should manage.
-Readonly
optsOptions for the pool.
-Protected
Readonly
optsOptions for this fixed thread pool.
+Protected
promiseThe execution response promise map.
+Protected
promiseThe 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.
-Protected
workerProtected
workerWorker choice strategy context referencing a worker choice algorithm implementation.
-Default to a round robin algorithm.
-Readonly
workerReadonly
Internal
workerPool worker nodes.
-Inherited from FixedThreadPool.workerNodes
Protected
busyWhether the pool is busy or not.
The pool busyness boolean status.
Overrides FixedThreadPool.busy
Protected
fullWhether the pool is full or not.
The pool filling boolean status.
Overrides FixedThreadPool.full
+Inherited from FixedThreadPool.full
Private
numberNumber of tasks queued in the pool.
+Pool information.
Inherited from FixedThreadPool.numberOfQueuedTasks
+Inherited from FixedThreadPool.info
Private
numberProtected
maxNumber of tasks running in the pool.
+The pool maximum size.
Inherited from FixedThreadPool.numberOfRunningTasks
+Inherited from FixedThreadPool.maxSize
Protected
minPool type.
+The pool minimum size.
+Inherited from FixedThreadPool.minSize
+Private
readyThe pool readiness boolean status.
+Inherited from FixedThreadPool.ready
+Protected
typeThe pool type.
If it is 'dynamic'
, it provides the max
property.
Overrides FixedThreadPool.type
Private
utilizationThe approximate pool utilization.
+The pool utilization.
+ +Inherited from FixedThreadPool.utilization
+Protected
workerThe worker type.
+Inherited from FixedThreadPool.worker
+Protected
afterAdds a task function to this pool. +If a task function with the same name already exists, it will be overwritten.
+The name of the task function.
+The task function.
+true
if the task function was added, false
otherwise.
https://nodejs.org/api/errors.html#class-typeerror If the name
parameter is not a string or an empty string.
https://nodejs.org/api/errors.html#class-typeerror If the fn
parameter is not a function.
Inherited from FixedThreadPool.addTaskFunction
+Protected
afterHook executed after the worker task execution. Can be overridden.
@@ -280,40 +407,45 @@ Can be overridden.The worker.
-The worker node key.
+The received message.
-Inherited from FixedThreadPool.afterTaskExecutionHook
Protected
afterProtected
afterFunction that can be hooked up when a worker has been newly created and moved to the pool worker nodes.
-Can be used to update the maxListeners
or binding the main-worker
<->worker
connection if not bind by default.
Method hooked up after a worker node has been newly created. +Can be overridden.
The newly created worker.
-Inherited from FixedThreadPool.afterWorkerSetup
+The newly created worker node key.
+Inherited from FixedThreadPool.afterWorkerNodeSetup
Protected
beforeProtected
beforeThe task to execute.
+Inherited from FixedThreadPool.beforeTaskExecutionHook
Protected
chooseProtected
createChooses a worker node for the next task.
-The default uses a round robin algorithm to distribute the load.
- -[worker node key, worker node].
+Creates a new, completely set up dynamic worker node.
Inherited from FixedThreadPool.chooseWorkerNode
+New, completely set up dynamic worker node key.
+ +Inherited from FixedThreadPool.createAndSetupDynamicWorkerNode
Protected
createProtected
createCreates a new worker and sets it up completely in the pool worker nodes.
- -New, completely set up worker.
+Creates a new, completely set up worker node.
Inherited from FixedThreadPool.createAndSetupWorker
+New, completely set up worker node key.
+ +Inherited from FixedThreadPool.createAndSetupWorkerNode
Protected
createProtected
createReturns a newly created worker.
+Creates a new worker.
Newly created worker.
+ +Inherited from FixedThreadPool.createWorker
Protected
deregisterDeregisters a listener callback on the worker given its worker node key.
+The worker node key.
+The message listener callback.
+Inherited from FixedThreadPool.deregisterWorkerMessageListener
+Shutdowns every current worker in this pool.
+Terminates all workers in this pool.
Inherited from FixedThreadPool.destroy
Protected
destroyShutdowns the given worker.
+Terminates the worker node given its worker node key.
A worker within workerNodes
.
Inherited from FixedThreadPool.destroyWorker
+The worker node key.
+Inherited from FixedThreadPool.destroyWorkerNode
Performs the task specified in the constructor with the data parameter.
- -Promise that will be resolved when the task is successfully completed.
+Enables/disables the worker node tasks queue in this pool.
The input for the specified task. This can only be serializable data.
-Whether to enable or disable the worker node tasks queue.
+Optional
tasksQueueOptions: TasksQueueOptionsThe worker node tasks queue options.
+Inherited from FixedThreadPool.enableTasksQueue
+Executes the specified function in the worker constructor with the task data input parameter.
+Optional
data: DataThe optional task input data for the specified task function. This can only be structured-cloneable data.
+Optional
name: stringThe optional name of the task function to execute. If not specified, the default task function will be executed.
+Optional
transferList: TransferListItem[]An optional array of transferable objects to transfer ownership of. Ownership of the transferred objects is given to the pool's worker_threads worker and they should not be used in the main thread afterwards.
+Promise that will be fulfilled when the task is completed.
+ +Inherited from FixedThreadPool.execute
Protected
flagInherited from FixedThreadPool.flagWorkerNodeAsNotReady
+Protected
flushInherited from FixedThreadPool.flushTasksQueue
+Protected
getFinds a free worker node key based on the number of tasks the worker has applied.
-If a worker is found with 0
running tasks, it is detected as free and its worker node key is returned.
If no free worker is found, -1
is returned.
Gets the worker information given its worker node key.
+The worker node key.
+The worker information.
-A worker node key if there is one, -1
otherwise.
Inherited from FixedThreadPool.getWorkerInfo
+Whether the specified task function exists in this pool.
+The name of the task function.
Inherited from FixedThreadPool.findFreeWorkerNodeKey
+true
if the task function exists, false
otherwise.
Inherited from FixedThreadPool.hasTaskFunction
Protected
internalInternal
+Whether the worker node has back pressure (i.e. its tasks queue is full).
+The worker node key.
+true
if the worker node has back pressure, false
otherwise.
Inherited from FixedThreadPool.hasWorkerNodeBackPressure
+Protected
internalWhether worker nodes are executing concurrently their tasks quota or not.
+Worker nodes busyness boolean status.
+ +Inherited from FixedThreadPool.internalBusy
Protected
isProtected
isShould return whether the worker is the main worker or not.
Inherited from FixedThreadPool.isMain
Registers a listener callback on the given worker.
+Lists the names of task function available in this pool.
The names of task function available in this pool.
+ +Inherited from FixedThreadPool.listTaskFunctionNames
+Protected
registerThe worker which should register a listener.
-The worker node key.
+The message listener callback.
Inherited from FixedThreadPool.registerOnceWorkerMessageListener
+Protected
registerRegisters a listener callback on the worker given its worker node key.
+The worker node key.
+The message listener callback.
+Inherited from FixedThreadPool.registerWorkerMessageListener
Protected
sendSends a message to the given worker.
+Removes a task function from this pool.
The worker which should receive the message.
-The name of the task function.
+true
if the task function was removed, false
otherwise.
Inherited from FixedThreadPool.removeTaskFunction
+Protected
sendInherited from FixedThreadPool.sendKillMessageToWorker
+Protected
sendSends the startup message to worker given its worker node key.
+The worker node key.
+Inherited from FixedThreadPool.sendStartupMessageToWorker
+Protected
sendSends a message to worker given its worker node key.
+The worker node key.
+The message.
-Optional
transferList: TransferListItem[]The optional array of transferable objects.
+Inherited from FixedThreadPool.sendToWorker
Sets the default task function in this pool.
+The name of the task function.
+true
if the default task function was set, false
otherwise.
Inherited from FixedThreadPool.setDefaultTaskFunction
+Sets the worker node tasks queue options in this pool.
+The worker node tasks queue options.
+Inherited from FixedThreadPool.setTasksQueueOptions
+Sets the worker choice strategy in this pool.
The worker choice strategy.
-Optional
workerChoiceStrategyOptions: WorkerChoiceStrategyOptionsThe worker choice strategy options.
+Inherited from FixedThreadPool.setWorkerChoiceStrategy
Protected
setupSetup hook to execute code before worker node are created in the abstract constructor. -Can be overridden
+Sets the worker choice strategy options in this pool.
The worker choice strategy options.
+Inherited from FixedThreadPool.setWorkerChoiceStrategyOptions
+Protected
setupSetup hook to execute code before worker nodes are created in the abstract constructor. +Can be overridden.
+Inherited from FixedThreadPool.setupHook
Protected
workerThis function is the listener registered for each worker message.
- -The listener function to execute when a message is received from a worker.
+Starts the minimum number of workers in this pool.
Inherited from FixedThreadPool.start
+Protected
workerThis function is the listener registered for each worker message.
- -The listener function to execute when a message is received from a worker.
+This method is the message listener registered on each worker.
Inherited from FixedThreadPool.workerListener
+Inherited from FixedThreadPool.workerMessageListener
Generated using TypeDoc
Generated using TypeDoc
+ \ No newline at end of file
A thread pool with a dynamic number of threads, but a guaranteed minimum number of threads.
This thread pool creates new threads when the others are busy, up to the maximum number of threads. When the maximum number of threads is reached and workers are busy, an event is emitted. If you want to listen to this event, use the pool's
+emitter
.