forked from camesine/Typescript-restful-starter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Index.ts
71 lines (59 loc) · 2.15 KB
/
Index.ts
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
import * as cluster from "cluster";
import { cpus } from "os";
import { env } from "process";
import { config } from "./config";
import logger from "./config/Logger";
import { Server } from "./config/Server";
if (cluster.isMaster) {
console.log(`\n -------------------> RUN ${env.NODE_ENV} ENVIRONMENT \n`);
for (const cpu of cpus()) {
cluster.fork();
}
cluster.on("exit", (worker, code, signal) => {
console.log("Worker " + worker.process.pid + " died with code: " + code + ", and signal: " + signal);
console.log("Starting a new worker");
cluster.fork();
});
} else {
const port: number = Number(env.PORT) || config.PORT_APP || 3000;
try {
new Server().Start().then((server) => {
server.listen(port);
server.on("error", (error: any) => {
if (error.syscall !== "listen") {
throw error;
}
switch (error.code) {
case "EACCES":
console.error("Port requires elevated privileges");
process.exit(1);
break;
case "EADDRINUSE":
console.error("Port is already in use");
process.exit(1);
break;
default:
throw error;
}
});
server.on("listening", () => {
console.log("Server is running in process " + process.pid + " listening on PORT " + port + "\n");
});
});
} catch (error) {
logger.warn(error.stack);
}
process
.on("unhandledRejection", (reason, p) => {
console.error(reason, "Unhandled Rejection at Promise", p);
logger.warn(reason.stack, "Unhandled Rejection at Promise ", p);
})
.on("uncaughtException", (err) => {
console.error(err, "Uncaught Exception thrown");
logger.error(err.stack, "Uncaught Exception thrown");
process.exit(1);
})
.on("warning", (warn) => {
logger.warn(warn);
});
}