repositories
/
poolifier.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge dependabot/npm_and_yarn/examples/typescript/websocket-server-pool/ws-hybrid...
[poolifier.git]
/
examples
/
typescript
/
http-server-pool
/
express-hybrid
/
src
/
express-worker.ts
diff --git
a/examples/typescript/http-server-pool/express-hybrid/src/express-worker.ts
b/examples/typescript/http-server-pool/express-hybrid/src/express-worker.ts
index a8ffbcb28fe0a5e6205b48964596d79d9520be41..7ba9f374f5fa248012fab50afb72e508f8391de4 100644
(file)
--- a/
examples/typescript/http-server-pool/express-hybrid/src/express-worker.ts
+++ b/
examples/typescript/http-server-pool/express-hybrid/src/express-worker.ts
@@
-1,11
+1,13
@@
-import type { Server } from 'http'
-import type { AddressInfo } from 'net'
+import type { Server } from 'node:http'
+import type { AddressInfo } from 'node:net'
+
+import express, { type Express, type Request, type Response } from 'express'
import {
import {
+ availableParallelism,
ClusterWorker,
ClusterWorker,
- DynamicThreadPool,
- availableParallelism
+ DynamicThreadPool
} from 'poolifier'
} from 'poolifier'
-import express, { type Express, type Request, type Response } from 'express'
+
import {
type ClusterWorkerData,
type ClusterWorkerResponse,
import {
type ClusterWorkerData,
type ClusterWorkerResponse,
@@
-15,7
+17,7
@@
import {
} from './types.js'
const emptyFunction = (): void => {
} from './types.js'
const emptyFunction = (): void => {
- /*
*
Intentional */
+ /* Intentional */
}
class ExpressWorker extends ClusterWorker<
}
class ExpressWorker extends ClusterWorker<
@@
-31,8
+33,8
@@
ClusterWorkerResponse
private static readonly startExpress = (
workerData?: ClusterWorkerData
): ClusterWorkerResponse => {
private static readonly startExpress = (
workerData?: ClusterWorkerData
): ClusterWorkerResponse => {
- const { port, workerFile, minWorkers, maxWorkers } =
- workerData
as ClusterWorkerData
+ const { port, workerFile, minWorkers, maxWorkers
, ...poolOptions
} =
+ workerData
!
ExpressWorker.requestHandlerPool = new DynamicThreadPool<
ThreadWorkerData<DataPayload>,
ExpressWorker.requestHandlerPool = new DynamicThreadPool<
ThreadWorkerData<DataPayload>,
@@
-41,7
+43,7
@@
ClusterWorkerResponse
minWorkers ?? 1,
maxWorkers ?? availableParallelism(),
workerFile,
minWorkers ?? 1,
maxWorkers ?? availableParallelism(),
workerFile,
- workerData
+ poolOptions
)
const application: Express = express()
)
const application: Express = express()
@@
-52,7
+54,7
@@
ClusterWorkerResponse
application.all('/api/echo', (req: Request, res: Response) => {
ExpressWorker.requestHandlerPool
.execute({ data: req.body }, 'echo')
application.all('/api/echo', (req: Request, res: Response) => {
ExpressWorker.requestHandlerPool
.execute({ data: req.body }, 'echo')
- .then(
(response)
=> {
+ .then(
response
=> {
return res.send(response.data).end()
})
.catch(emptyFunction)
return res.send(response.data).end()
})
.catch(emptyFunction)
@@
-62,23
+64,22
@@
ClusterWorkerResponse
const { number } = req.params
ExpressWorker.requestHandlerPool
.execute({ data: { number: parseInt(number) } }, 'factorial')
const { number } = req.params
ExpressWorker.requestHandlerPool
.execute({ data: { number: parseInt(number) } }, 'factorial')
- .then(
(response)
=> {
+ .then(
response
=> {
return res.send(response.data).end()
})
.catch(emptyFunction)
})
return res.send(response.data).end()
})
.catch(emptyFunction)
})
+ let listenerPort: number | undefined
ExpressWorker.server = application.listen(port, () => {
ExpressWorker.server = application.listen(port, () => {
+ listenerPort = (ExpressWorker.server.address() as AddressInfo).port
console.info(
console.info(
- // eslint-disable-next-line @typescript-eslint/restrict-template-expressions
- `⚡️[express server]: Express server is started in cluster worker at http://localhost:${workerData?.port}/`
+ `⚡️[express server]: Express server is started in cluster worker at http://localhost:${listenerPort}/`
)
})
return {
status: true,
)
})
return {
status: true,
- port:
- (ExpressWorker.server.address() as AddressInfo)?.port ??
- workerData?.port
+ port: listenerPort ?? port
}
}
}
}