-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.ts
89 lines (74 loc) · 2.08 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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
import express from 'express';
import http from 'http';
import bodyParser from 'body-parser';
import cookieParser from 'cookie-parser';
import compression from 'compression';
import cors from 'cors';
import morgan from 'morgan';
import { Server } from 'socket.io';
// workers
import cluster from 'cluster';
import os from 'os';
import { createAdapter, setupPrimary } from '@socket.io/cluster-adapter';
import { setupWorker, setupMaster } from '@socket.io/sticky';
import router from './router';
const app = express();
app.use(
cors({
credentials: true,
})
);
if (cluster.isPrimary) {
const httpServer = http.createServer();
// setup sticky sessions
setupMaster(httpServer, {
loadBalancingMethod: 'least-connection',
});
// setup primary
setupPrimary();
cluster.setupPrimary({
serialization: 'advanced',
});
httpServer.listen(8080, () => {
console.log(`Primary ${process.pid} started listening on port 8080`);
});
for (let i = 0; i < os.cpus().length; i++) {
cluster.fork();
}
cluster.on('exit', (worker) => {
console.log(`Worker ${worker.process.pid} died`);
cluster.fork();
});
} else {
app.use(compression());
app.use(cookieParser());
app.use(bodyParser.json());
app.use(morgan('dev'));
const server = http.createServer(app);
const io = new Server(server, {
cors: {
origin: 'http://localhost:5173',
methods: ['GET', 'POST'],
},
});
// use the cluster adapter
io.adapter(createAdapter());
// setup connection with the primary process
setupWorker(io);
// Socket io: It listens to 'connection' event
io.on('connection', (socket) => {
socket.on('new_message', (data) => {
if (data.roomID) {
socket.to(data.roomID).emit('receive_message', data.message);
return;
}
// We use this to send message to everyone excluding the sender
// socket.broadcast.emit('receive_message', data.message);
});
socket.on('join_room', (data) => {
socket.join(data.roomID);
socket.to(data.roomID).emit('user_joined', data.username);
});
});
app.use('/', router());
}