summary refs log tree commit diff
path: root/bundle/src/start.ts
blob: f68a65bf8c335667079fa7d00765e7c722f9103f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
// process.env.MONGOMS_DEBUG = "true";
import cluster from "cluster";
import os from "os";
import { initStats } from "./stats";

// TODO: add tcp socket event transmission
const cores = 1 || Number(process.env.threads) || os.cpus().length;

if (cluster.isMaster && !process.env.masterStarted) {
	process.env.masterStarted = "true";

	(async () => {
		initStats();

		if (cores === 1) {
			require("./Server");
			return;
		}

		// Fork workers.
		for (let i = 0; i < cores; i++) {
			cluster.fork();
		}

		cluster.on("exit", (worker: any, code: any, signal: any) => {
			console.log(
				`[Worker] died with pid: ${worker.process.pid} , restarting ...`
			);
			cluster.fork();
		});
	})();
} else {
	require("./Server");
}