1 import { dirname
, extname
, join
} from
'node:path'
2 import { fileURLToPath
} from
'node:url'
3 import { FixedClusterPool
, availableParallelism
} from
'poolifier'
4 import { type WorkerData
, type WorkerResponse
} from
'./types.js'
6 const workerFile
= join(
7 dirname(fileURLToPath(import.meta
.url
)),
8 `worker${extname(fileURLToPath(import.meta.url))}`
11 const pool
= new FixedClusterPool
<WorkerData
, WorkerResponse
>(
12 availableParallelism(),
15 errorHandler
: (e
: Error) => {
21 // Start one ws server instance per cluster worker in the pool
22 for (let i
= 1; i
<= pool
.info
.maxSize
; i
++) {
24 .execute({ port
: 8080 })
26 if (response
.status) {
28 // eslint-disable-next-line @typescript-eslint/restrict-template-expressions
29 `WebSocket server is listening on worker ${i} on port ${response.port}`
33 `WebSocket server failed to start on worker ${i}:`,