1 import { dirname
, extname
, join
} from
'node:path'
2 import { fileURLToPath
} from
'node:url'
3 import { availableParallelism
, FixedClusterPool
} from
'poolifier'
5 import type { WorkerData
, WorkerResponse
} from
'./types.js'
7 const workerFile
= join(
8 dirname(fileURLToPath(import.meta
.url
)),
9 `worker${extname(fileURLToPath(import.meta.url))}`
12 const pool
= new FixedClusterPool
<WorkerData
, WorkerResponse
>(
13 availableParallelism(),
17 errorHandler
: (e
: Error) => {
18 console
.error('Cluster worker error:', e
)
20 onlineHandler
: () => {
22 .execute({ port
: 8080 })
24 if (response
.status) {
26 `Fastify is listening in cluster worker on port ${response.port?.toString()}`
31 .catch((error
: unknown
) => {
32 console
.error('Fastify failed to start in cluster worker:', error
)