-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.ts
61 lines (52 loc) · 1.58 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
import net from "node:net";
import { parseRequest } from "./parser";
import { createResponse, getTemplate } from "./response";
import { manageRoutes } from "./router";
import cluster from "cluster";
import { cpus } from "os";
if (cluster.isPrimary) {
console.log(`Primary ${process.pid} is running`);
const numCPUs = cpus().length;
console.log(`Number of CPUs: ${numCPUs}`);
for (let i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on("exit", (worker) => {
console.log(`worker ${worker.process.pid} died`);
console.log("Let's fork another worker!");
cluster.fork();
});
} else {
const server = net.createServer().listen(3000, () => {
console.log("SOCKET SERVER Listening");
});
server.on("connection", (socket: net.Socket) => {
console.log("SERVER CONNECTED");
socket
.on("data", (data: Buffer | string) => {
console.log(`[process ${process.pid}]`);
const request = parseRequest(data);
if (request) {
try {
const page = manageRoutes(request);
const template = getTemplate(page);
const response = createResponse(request, template);
socket.write(response);
} catch (error) {
socket.write(
"HTTP/1.1\r\n\r\n" + (error as { message: string }).message
);
}
}
// close the socket
socket.end();
})
.on("end", () => {
console.log("SOCKET ENDED");
});
});
server.on("error", (err) => {
console.log(`[process ${process.pid}] : ${err}`);
process.exit(1);
});
}