DynamicThreadPool
} from 'poolifier'
-import {
- type ClusterWorkerData,
- type ClusterWorkerResponse,
- type DataPayload,
- type ThreadWorkerData,
- type ThreadWorkerResponse
+import type {
+ ClusterWorkerData,
+ ClusterWorkerResponse,
+ DataPayload,
+ ThreadWorkerData,
+ ThreadWorkerResponse
} from './types.js'
const emptyFunction = (): void => {
application.get('/api/factorial/:number', (req: Request, res: Response) => {
const { number } = req.params
ExpressWorker.requestHandlerPool
- .execute({ data: { number: parseInt(number) } }, 'factorial')
+ .execute({ data: { number: Number.parseInt(number) } }, 'factorial')
.then(response => {
return res.send(response.data).end()
})
.catch(emptyFunction)
})
+ let listenerPort: number | undefined
ExpressWorker.server = application.listen(port, () => {
+ listenerPort = (ExpressWorker.server.address() as AddressInfo).port
console.info(
- `⚡️[express server]: Express server is started in cluster worker at http://localhost:${port}/`
+ `⚡️[express server]: Express server is started in cluster worker at http://localhost:${listenerPort}/`
)
})
return {
status: true,
- port: (ExpressWorker.server.address() as AddressInfo).port
+ port: listenerPort ?? port
}
}