1 import type { MessageChannel
} from
'node:worker_threads'
2 import type { CircularArray
} from
'../circular-array'
3 import type { Task
} from
'../utility-types'
6 * Callback invoked when the worker has started successfully.
8 * @typeParam Worker - Type of worker.
10 export type OnlineHandler
<Worker
extends IWorker
> = (this: Worker
) => void
13 * Callback invoked if the worker has received a message.
15 * @typeParam Worker - Type of worker.
17 export type MessageHandler
<Worker
extends IWorker
> = (
23 * Callback invoked if the worker raised an error.
25 * @typeParam Worker - Type of worker.
27 export type ErrorHandler
<Worker
extends IWorker
> = (
33 * Callback invoked when the worker exits successfully.
35 * @typeParam Worker - Type of worker.
37 export type ExitHandler
<Worker
extends IWorker
> = (
43 * Measurement statistics.
47 export interface MeasurementStatistics
{
49 * Measurement aggregate.
53 * Measurement minimum.
57 * Measurement maximum.
61 * Measurement average.
69 * Measurement history.
71 readonly history
: CircularArray
<number>
75 * Event loop utilization measurement statistics.
79 export interface EventLoopUtilizationMeasurementStatistics
{
80 readonly idle
: MeasurementStatistics
81 readonly active
: MeasurementStatistics
90 export interface TaskStatistics
{
92 * Number of executed tasks.
96 * Number of executing tasks.
100 * Number of queued tasks.
102 readonly queued
: number
104 * Maximum number of queued tasks.
106 readonly maxQueued
?: number
108 * Number of sequentially stolen tasks.
110 sequentiallyStolen
: number
112 * Number of stolen tasks.
116 * Number of failed tasks.
122 * Enumeration of worker types.
124 export const WorkerTypes
= Object.freeze({
132 export type WorkerType
= keyof
typeof WorkerTypes
135 * Worker information.
139 export interface WorkerInfo
{
143 readonly id
: number | undefined
147 readonly type: WorkerType
157 * Task function names.
159 taskFunctionNames
?: string[]
163 * Worker usage statistics.
167 export interface WorkerUsage
{
171 readonly tasks
: TaskStatistics
173 * Tasks runtime statistics.
175 readonly runTime
: MeasurementStatistics
177 * Tasks wait time statistics.
179 readonly waitTime
: MeasurementStatistics
181 * Tasks event loop utilization statistics.
183 readonly elu
: EventLoopUtilizationMeasurementStatistics
187 * Worker choice strategy data.
191 export interface StrategyData
{
192 virtualTaskEndTimestamp
?: number
198 export interface IWorker
{
203 readonly threadId
?: number
205 * Registers an event listener.
207 * @param event - The event.
208 * @param handler - The event handler.
210 readonly on
: ((event
: 'online', handler
: OnlineHandler
<this>) => void) &
211 ((event
: 'message', handler
: MessageHandler
<this>) => void) &
212 ((event
: 'error', handler
: ErrorHandler
<this>) => void) &
213 ((event
: 'exit', handler
: ExitHandler
<this>) => void)
215 * Registers a listener to the exit event that will only be performed once.
217 * @param event - The `'exit'` event.
218 * @param handler - The exit handler.
220 readonly once
: (event
: 'exit', handler
: ExitHandler
<this>) => void
224 * Worker node event detail.
228 export interface WorkerNodeEventDetail
{
230 workerNodeKey
?: number
234 * Worker node interface.
236 * @typeParam Worker - Type of worker.
237 * @typeParam Data - Type of data sent to the worker. This can only be structured-cloneable data.
240 export interface IWorkerNode
<Worker
extends IWorker
, Data
= unknown
>
241 extends EventTarget
{
245 readonly worker
: Worker
249 readonly info
: WorkerInfo
251 * Worker usage statistics.
253 readonly usage
: WorkerUsage
255 * Worker choice strategy data.
256 * This is used to store data that are specific to the worker choice strategy.
258 strategyData
?: StrategyData
260 * Message channel (worker_threads only).
262 readonly messageChannel
?: MessageChannel
264 * Tasks queue back pressure size.
265 * This is the number of tasks that can be enqueued before the worker node has back pressure.
267 tasksQueueBackPressureSize
: number
271 * @returns The tasks queue size.
273 readonly tasksQueueSize
: () => number
277 * @param task - The task to queue.
278 * @returns The tasks queue size.
280 readonly enqueueTask
: (task
: Task
<Data
>) => number
282 * Prepends a task to the tasks queue.
284 * @param task - The task to prepend.
285 * @returns The tasks queue size.
287 readonly unshiftTask
: (task
: Task
<Data
>) => number
291 * @returns The dequeued task.
293 readonly dequeueTask
: () => Task
<Data
> | undefined
295 * Pops a task from the tasks queue.
297 * @returns The popped task.
299 readonly popTask
: () => Task
<Data
> | undefined
301 * Clears tasks queue.
303 readonly clearTasksQueue
: () => void
305 * Whether the worker node has back pressure (i.e. its tasks queue is full).
307 * @returns `true` if the worker node has back pressure, `false` otherwise.
309 readonly hasBackPressure
: () => boolean
311 * Resets usage statistics.
313 readonly resetUsage
: () => void
315 * Closes communication channel.
317 readonly closeChannel
: () => void
319 * Gets task function worker usage statistics.
321 * @param name - The task function name.
322 * @returns The task function worker usage statistics if the task function worker usage statistics are initialized, `undefined` otherwise.
324 readonly getTaskFunctionWorkerUsage
: (name
: string) => WorkerUsage
| undefined
326 * Deletes task function worker usage statistics.
328 * @param name - The task function name.
329 * @returns `true` if the task function worker usage statistics were deleted, `false` otherwise.
331 readonly deleteTaskFunctionWorkerUsage
: (name
: string) => boolean