1 import type { MessageChannel
} from
'node:worker_threads'
2 import type { EventEmitter
} from
'node:events'
3 import type { CircularArray
} from
'../circular-array'
4 import type { Task
} from
'../utility-types'
7 * Callback invoked when the worker has started successfully.
9 * @typeParam Worker - Type of worker.
11 export type OnlineHandler
<Worker
extends IWorker
> = (this: Worker
) => void
14 * Callback invoked if the worker has received a message.
16 * @typeParam Worker - Type of worker.
18 export type MessageHandler
<Worker
extends IWorker
> = (
24 * Callback invoked if the worker raised an error.
26 * @typeParam Worker - Type of worker.
28 export type ErrorHandler
<Worker
extends IWorker
> = (
34 * Callback invoked when the worker exits successfully.
36 * @typeParam Worker - Type of worker.
38 export type ExitHandler
<Worker
extends IWorker
> = (
44 * Measurement statistics.
48 export interface MeasurementStatistics
{
50 * Measurement aggregate.
54 * Measurement minimum.
58 * Measurement maximum.
62 * Measurement average.
70 * Measurement history.
72 readonly history
: CircularArray
<number>
76 * Event loop utilization measurement statistics.
80 export interface EventLoopUtilizationMeasurementStatistics
{
81 readonly idle
: MeasurementStatistics
82 readonly active
: MeasurementStatistics
91 export interface TaskStatistics
{
93 * Number of executed tasks.
97 * Number of executing tasks.
101 * Number of queued tasks.
103 readonly queued
: number
105 * Maximum number of queued tasks.
107 readonly maxQueued
?: number
109 * Number of sequentially stolen tasks.
111 sequentiallyStolen
: number
113 * Number of stolen tasks.
117 * Number of failed tasks.
123 * Enumeration of worker types.
125 export const WorkerTypes
= Object.freeze({
133 export type WorkerType
= keyof
typeof WorkerTypes
136 * Worker information.
140 export interface WorkerInfo
{
144 readonly id
: number | undefined
148 readonly type: WorkerType
158 * Task function names.
160 taskFunctionNames
?: string[]
164 * Worker usage statistics.
168 export interface WorkerUsage
{
172 readonly tasks
: TaskStatistics
174 * Tasks runtime statistics.
176 readonly runTime
: MeasurementStatistics
178 * Tasks wait time statistics.
180 readonly waitTime
: MeasurementStatistics
182 * Tasks event loop utilization statistics.
184 readonly elu
: EventLoopUtilizationMeasurementStatistics
188 * Worker choice strategy data.
192 export interface StrategyData
{
193 virtualTaskEndTimestamp
?: number
199 export interface IWorker
{
204 readonly threadId
?: number
206 * Registers an event listener.
208 * @param event - The event.
209 * @param handler - The event handler.
214 | OnlineHandler
<this>
215 | MessageHandler
<this>
220 * Registers once an event listener.
222 * @param event - The event.
223 * @param handler - The event handler.
228 | OnlineHandler
<this>
229 | MessageHandler
<this>
236 * Worker node options.
240 export interface WorkerNodeOptions
{
241 workerOptions
?: WorkerOptions
242 env
?: Record
<string, unknown
>
243 tasksQueueBackPressureSize
: number
247 * Worker node interface.
249 * @typeParam Worker - Type of worker.
250 * @typeParam Data - Type of data sent to the worker. This can only be structured-cloneable data.
253 export interface IWorkerNode
<Worker
extends IWorker
, Data
= unknown
>
254 extends EventEmitter
{
258 readonly worker
: Worker
262 readonly info
: WorkerInfo
264 * Worker usage statistics.
266 readonly usage
: WorkerUsage
268 * Worker choice strategy data.
269 * This is used to store data that are specific to the worker choice strategy.
271 strategyData
?: StrategyData
273 * Message channel (worker_threads only).
275 readonly messageChannel
?: MessageChannel
277 * Tasks queue back pressure size.
278 * This is the number of tasks that can be enqueued before the worker node has back pressure.
280 tasksQueueBackPressureSize
: number
284 * @returns The tasks queue size.
286 readonly tasksQueueSize
: () => number
290 * @param task - The task to queue.
291 * @returns The tasks queue size.
293 readonly enqueueTask
: (task
: Task
<Data
>) => number
295 * Prepends a task to the tasks queue.
297 * @param task - The task to prepend.
298 * @returns The tasks queue size.
300 readonly unshiftTask
: (task
: Task
<Data
>) => number
304 * @returns The dequeued task.
306 readonly dequeueTask
: () => Task
<Data
> | undefined
308 * Pops a task from the tasks queue.
310 * @returns The popped task.
312 readonly popTask
: () => Task
<Data
> | undefined
314 * Clears tasks queue.
316 readonly clearTasksQueue
: () => void
318 * Whether the worker node has back pressure (i.e. its tasks queue is full).
320 * @returns `true` if the worker node has back pressure, `false` otherwise.
322 readonly hasBackPressure
: () => boolean
324 * Resets usage statistics.
326 readonly resetUsage
: () => void
328 * Closes communication channel.
330 readonly closeChannel
: () => void
332 * Registers a worker event handler.
334 * @param event - The event.
335 * @param listener - The event listener.
337 readonly registerWorkerEventHandler
: (
340 | OnlineHandler
<Worker
>
341 | MessageHandler
<Worker
>
342 | ErrorHandler
<Worker
>
343 | ExitHandler
<Worker
>
346 * Registers once a worker event handler.
348 * @param event - The event.
349 * @param listener - The event listener.
351 readonly registerOnceWorkerEventHandler
: (
354 | OnlineHandler
<Worker
>
355 | MessageHandler
<Worker
>
356 | ErrorHandler
<Worker
>
357 | ExitHandler
<Worker
>
360 * Gets task function worker usage statistics.
362 * @param name - The task function name.
363 * @returns The task function worker usage statistics if the task function worker usage statistics are initialized, `undefined` otherwise.
365 readonly getTaskFunctionWorkerUsage
: (name
: string) => WorkerUsage
| undefined
367 * Deletes task function worker usage statistics.
369 * @param name - The task function name.
370 * @returns `true` if the task function worker usage statistics were deleted, `false` otherwise.
372 readonly deleteTaskFunctionWorkerUsage
: (name
: string) => boolean
376 * Worker node event detail.
380 export interface WorkerNodeEventDetail
{
382 workerNodeKey
?: number