My question is, now that I need a load balancer something else, or this Worker that I create according to the CPUs Core size works perfectly well in the node app.
const express = require("express");
const cluster = require("cluster");
const totalCPUs = require("os").cpus().length;
const PORT = process.env.PORT || 3000;
if (cluster.isMaster) {
console.log(`Number of CPUs is ${totalCPUs}`);
// Fork workers.
for (let i = 0; i < totalCPUs; i++) {
cluster.fork();
}
cluster.on("exit", (worker, code, signal) => {
console.log(`worker ${worker.process.pid} died`);
console.log("Let's fork another worker!");
cluster.fork();
});
} else {
const app = express();
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
// Route Calling
const vehicleRoute = require("./routes/vehicle");
app.use("/api", vehicleRoute);
app.listen(PORT, () => {
console.log(`[${process.pid}]App listening on port ${PORT}`);
});
}