Usage in Deno
import { type Cluster } from "node:cluster";
isMaster: boolean
isPrimary: boolean
True if the process is a primary. This is determined by the process.env.NODE_UNIQUE_ID
. If process.env.NODE_UNIQUE_ID
is undefined, then isPrimary
is true
.
isWorker: boolean
True if the process is not a primary (it is the negation of cluster.isPrimary
).
schedulingPolicy: number
The scheduling policy, either cluster.SCHED_RR
for round-robin or cluster.SCHED_NONE
to leave it to the operating system. This is a
global setting and effectively frozen once either the first worker is spawned, or .setupPrimary()
is called, whichever comes first.
SCHED_RR
is the default on all operating systems except Windows. Windows will change to SCHED_RR
once libuv is able to effectively distribute
IOCP handles without incurring a large performance hit.
cluster.schedulingPolicy
can also be set through the NODE_CLUSTER_SCHED_POLICY
environment variable. Valid values are 'rr'
and 'none'
.
settings: ClusterSettings
After calling .setupPrimary()
(or .fork()
) this settings object will contain
the settings, including the default values.
This object is not intended to be changed or set manually.
A reference to the current worker object. Not available in the primary process.
import cluster from 'node:cluster'; if (cluster.isPrimary) { console.log('I am primary'); cluster.fork(); cluster.fork(); } else if (cluster.isWorker) { console.log(`I am worker #${cluster.worker.id}`); }
A hash that stores the active worker objects, keyed by id
field. This makes it easy to loop through all the workers. It is only available in the primary process.
A worker is removed from cluster.workers
after the worker has disconnected and exited. The order between these two events cannot be determined in advance. However, it
is guaranteed that the removal from the cluster.workers
list happens before the last 'disconnect'
or 'exit'
event is emitted.
import cluster from 'node:cluster'; for (const worker of Object.values(cluster.workers)) { worker.send('big announcement to all workers'); }
SCHED_NONE: number
SCHED_RR: number
disconnect(callback?: () => void): void
Spawn a new worker process.
This can only be called from the primary process.
setupMaster(settings?: ClusterSettings): void
setupPrimary(settings?: ClusterSettings): void
setupPrimary
is used to change the default 'fork' behavior. Once called, the settings will be present in cluster.settings
.
Any settings changes only affect future calls to .fork()
and have no effect on workers that are already running.
The only attribute of a worker that cannot be set via .setupPrimary()
is the env
passed to
.fork()
.
The defaults above apply to the first call only; the defaults for later calls are the current values at the time of
cluster.setupPrimary()
is called.
import cluster from 'node:cluster'; cluster.setupPrimary({ exec: 'worker.js', args: ['--use', 'https'], silent: true, }); cluster.fork(); // https worker cluster.setupPrimary({ exec: 'worker.js', args: ['--use', 'http'], }); cluster.fork(); // http worker
This can only be called from the primary process.
addListener(event: string,listener: (...args: any[]) => void,): this
events.EventEmitter
- disconnect
- exit
- fork
- listening
- message
- online
- setup
addListener(event: "disconnect",listener: (worker: Worker) => void,): this
addListener(event: "exit",listener: () => void,): this
addListener(event: "fork",listener: (worker: Worker) => void,): this
addListener(): this
addListener(event: "message",listener: () => void,): this
addListener(event: "online",listener: (worker: Worker) => void,): this
addListener(event: "setup",listener: (settings: ClusterSettings) => void,): this
emit(event: string | symbol,...args: any[],): boolean
emit(event: "setup",settings: ClusterSettings,): boolean
on(event: string,listener: (...args: any[]) => void,): this
on(event: "setup",listener: (settings: ClusterSettings) => void,): this
once(event: string,listener: (...args: any[]) => void,): this
once(event: "setup",listener: (settings: ClusterSettings) => void,): this
prependListener(event: string,listener: (...args: any[]) => void,): this
prependListener(event: "disconnect",listener: (worker: Worker) => void,): this
prependListener(event: "exit",listener: () => void,): this
prependListener(event: "fork",listener: (worker: Worker) => void,): this
prependListener(): this
prependListener(event: "message",listener: () => void,): this
prependListener(event: "online",listener: (worker: Worker) => void,): this
prependListener(event: "setup",listener: (settings: ClusterSettings) => void,): this
prependOnceListener(event: string,listener: (...args: any[]) => void,): this
prependOnceListener(event: "disconnect",listener: (worker: Worker) => void,): this
prependOnceListener(event: "exit",listener: () => void,): this
prependOnceListener(event: "fork",listener: (worker: Worker) => void,): this
prependOnceListener(): this
prependOnceListener(event: "message",listener: () => void,): this
prependOnceListener(event: "online",listener: (worker: Worker) => void,): this
prependOnceListener(event: "setup",listener: (settings: ClusterSettings) => void,): this