0
0
Node.jsframework~10 mins

How cluster module works in Node.js - Visual Walkthrough

Choose your learning style9 modes available
Concept Flow - How cluster module works
Start Master Process
Fork Worker Processes
Workers Listen on Server Port
Master Distributes Incoming Requests
Workers Handle Requests Independently
If Worker Dies
Master Forks New Worker
Continue Serving
The master process starts and forks multiple worker processes. Each worker listens on the same server port. The master distributes incoming requests to workers. If a worker dies, the master replaces it.
Execution Sample
Node.js
import cluster from 'cluster';
import os from 'os';
import http from 'http';

if (cluster.isPrimary) {
  for (let i = 0; i < os.cpus().length; i++) cluster.fork();
} else {
  http.createServer((req, res) => res.end('Hello from worker')).listen(8000);
}
This code creates a master process that forks one worker per CPU core. Each worker runs an HTTP server on port 8000.
Execution Table
StepActionProcess TypeWorkers CountServer ListeningNotes
1Start scriptPrimary0NoMaster process begins
2Check if primaryPrimary0NoTrue, will fork workers
3Fork worker 1Primary1NoFirst worker created
4Fork worker 2Primary2NoSecond worker created
5Fork worker NPrimaryNNoAll workers forked (N = CPU count)
6Workers start serverWorkerNYesEach worker listens on port 8000
7Master distributes requestsPrimaryNNoIncoming requests load balanced
8Worker handles requestWorkerNYesResponds with 'Hello from worker'
9Worker crashesWorkerN-1YesOne worker dies
10Master forks new workerPrimaryNNoWorker count restored
11Continue servingPrimary & WorkersNYesServer runs continuously
💡 Server runs indefinitely until manually stopped
Variable Tracker
VariableStartAfter Fork 1After Fork 2After All ForksAfter Worker CrashAfter Replacement
cluster.isPrimarytruetruetruetruetruetrue
workers count012N (CPU count)N-1N
server listeningNoNoNoYes (in workers)YesYes
Key Moments - 3 Insights
Why do all workers listen on the same port without conflict?
The cluster module uses OS-level load balancing so multiple workers can share the same port safely, as shown in execution_table rows 6 and 7.
What happens if a worker process crashes?
The master detects the crash and forks a new worker to keep the count stable, as seen in rows 9 and 10 of the execution_table.
Is the master process handling requests directly?
No, the master only manages workers and distributes requests. Workers handle requests independently (rows 7 and 8).
Visual Quiz - 3 Questions
Test your understanding
Look at the execution_table, at which step do workers start listening on the server port?
AStep 9
BStep 3
CStep 6
DStep 2
💡 Hint
Check the 'Server Listening' column in execution_table row 6
According to variable_tracker, what happens to the workers count after a worker crashes?
AIt decreases by one
BIt increases
CIt stays the same
DIt becomes zero
💡 Hint
Look at 'workers count' row in variable_tracker after 'After Worker Crash' column
If the master process did not fork new workers after a crash, what would happen to the workers count?
AIt would remain at N
BIt would decrease and not recover
CIt would increase unexpectedly
DIt would reset to zero
💡 Hint
Refer to execution_table rows 9 and 10 about worker crash and replacement
Concept Snapshot
Node.js cluster module lets a master process fork multiple worker processes.
Workers share the same server port using OS load balancing.
Master manages workers and replaces any that crash.
This improves app performance by using multiple CPU cores.
Workers handle requests independently, master only manages.
Full Transcript
The Node.js cluster module works by starting a master process that forks multiple worker processes equal to the number of CPU cores. Each worker runs an HTTP server listening on the same port. The master process distributes incoming requests across these workers using operating system load balancing. If a worker crashes, the master detects this and forks a new worker to maintain the number of active workers. This setup allows Node.js applications to handle more requests concurrently by using all CPU cores efficiently. The master process itself does not handle requests but manages the workers. Workers independently respond to requests, improving performance and reliability.