X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=examples%2Ftypescript%2Fwebsocket-server-pool%2Fws-hybrid%2Fsrc%2Fwebsocket-server-worker.ts;h=437fae1b45600c5cb0bc700d690569c820b44b5e;hb=7d9756e3c95d4f46fab5f17080b107b825ec3890;hp=f495a7211024e75ea38cefa2f55c3a4614e6de77;hpb=8ebe6c308dc1fc3202980126da043b2855d24780;p=poolifier.git diff --git a/examples/typescript/websocket-server-pool/ws-hybrid/src/websocket-server-worker.ts b/examples/typescript/websocket-server-pool/ws-hybrid/src/websocket-server-worker.ts index f495a721..437fae1b 100644 --- a/examples/typescript/websocket-server-pool/ws-hybrid/src/websocket-server-worker.ts +++ b/examples/typescript/websocket-server-pool/ws-hybrid/src/websocket-server-worker.ts @@ -31,22 +31,25 @@ ClusterWorkerResponse private static readonly startWebSocketServer = ( workerData?: ClusterWorkerData ): ClusterWorkerResponse => { - const { port } = workerData as ClusterWorkerData - WebSocketServerWorker.wss = new WebSocketServer({ port }, () => { - console.info( - `⚡️[ws server]: WebSocket server is started in cluster worker at ws://localhost:${port}/` - ) - }) + const { port, workerFile, minWorkers, maxWorkers, ...poolOptions } = + workerData as ClusterWorkerData WebSocketServerWorker.requestHandlerPool = new DynamicThreadPool< ThreadWorkerData, ThreadWorkerResponse >( - workerData?.minWorkers ?? 1, - workerData?.maxWorkers ?? availableParallelism(), - workerData?.workerFile as string + minWorkers ?? 1, + maxWorkers ?? availableParallelism(), + workerFile, + poolOptions ) + WebSocketServerWorker.wss = new WebSocketServer({ port }, () => { + console.info( + `⚡️[ws server]: WebSocket server is started in cluster worker at ws://localhost:${port}/` + ) + }) + WebSocketServerWorker.wss.on('connection', (ws) => { ws.on('error', console.error) ws.on('message', (message: RawData) => { @@ -93,7 +96,12 @@ ClusterWorkerResponse } public constructor () { - super(WebSocketServerWorker.startWebSocketServer) + super(WebSocketServerWorker.startWebSocketServer, { + killHandler: async () => { + await WebSocketServerWorker.requestHandlerPool.destroy() + WebSocketServerWorker.wss.close() + } + }) } }