1 import { dirname
, extname
, join
} from
'node:path'
2 import { fileURLToPath
} from
'node:url'
4 import { availableParallelism
, DynamicThreadPool
} from
'poolifier'
6 import type { DataPayload
, WorkerData
, WorkerResponse
} from
'./types.js'
8 const workerFile
= join(
9 dirname(fileURLToPath(import.meta
.url
)),
10 `worker${extname(fileURLToPath(import.meta.url))}`
13 export const requestHandlerPool
= new DynamicThreadPool
<
14 WorkerData
<DataPayload
>,
15 WorkerResponse
<DataPayload
>
16 >(1, availableParallelism(), workerFile
, {
17 enableTasksQueue
: true,
21 errorHandler
: (e
: Error) => {
22 console
.error('Thread worker error:', e
)