1 import { dirname
, extname
, join
} from
'node:path'
2 import { exit
} from
'node:process'
3 import { fileURLToPath
} from
'node:url'
5 import Fastify from
'fastify'
7 import { fastifyPoolifier
} from
'./fastify-poolifier.js'
10 * The fastify server is still a single-threaded application, but the request handling can be multi-threaded.
14 const fastify
= Fastify({
18 const workerFile
= join(
19 dirname(fileURLToPath(import.meta
.url
)),
20 `worker${extname(fileURLToPath(import.meta.url))}`
23 await fastify
.register(fastifyPoolifier
, {
25 enableTasksQueue
: true,
29 errorHandler
: (e
: Error) => {
30 fastify
.log
.error('Thread worker error:', e
)
34 fastify
.all('/api/echo', async request
=> {
35 return (await fastify
.execute({ body
: request
.body
}, 'echo')).body
39 Params
: { number: number }
40 }>('/api/factorial/:number', async request
=> {
41 const { number } = request
.params
42 return (await fastify
.execute({ body
: { number } }, 'factorial')).body
46 await fastify
.listen({ port
})
48 fastify
.log
.error(err
)