1 import { dirname
, extname
, join
} from
'node:path'
2 import { fileURLToPath
} from
'node:url'
3 import { DynamicThreadPool
, availableParallelism
} from
'poolifier'
10 const workerFile
= join(
11 dirname(fileURLToPath(import.meta
.url
)),
12 `worker${extname(fileURLToPath(import.meta.url))}`
15 export const requestHandlerPool
= new DynamicThreadPool
<
16 WorkerData
<DataPayload
>,
17 WorkerResponse
<DataPayload
>
18 >(1, availableParallelism(), workerFile
, {
19 enableTasksQueue
: true,
23 errorHandler
: (e
: Error) => {
24 console
.error('Thread worker error:', e
)