X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=examples%2Ftypescript%2Fpool.ts;h=c55c4e96557dc8fcb400847745b0ac2c5ee014c7;hb=45560c0539e5668157f1352c984bcd2e8ded6124;hp=50dcc7b779d7118b27f42c56136fca509d58a7f6;hpb=7e00d939d448a0439a4bddbb64c06d28cb9527a0;p=poolifier.git diff --git a/examples/typescript/pool.ts b/examples/typescript/pool.ts index 50dcc7b7..c55c4e96 100644 --- a/examples/typescript/pool.ts +++ b/examples/typescript/pool.ts @@ -1,23 +1,48 @@ -import { DynamicThreadPool, FixedThreadPool } from 'poolifier' -import { MyData, MyResponse } from './worker' +import { dirname, extname, join } from 'node:path' +import { fileURLToPath } from 'node:url' -import { join } from 'path' +import { + availableParallelism, + DynamicThreadPool, + FixedThreadPool +} from 'poolifier' -export const fixedPool = new FixedThreadPool>( - 8, - join(__dirname, 'worker.js'), +import type { MyData, MyResponse } from './worker.js' + +const workerFile = join( + dirname(fileURLToPath(import.meta.url)), + `worker${extname(fileURLToPath(import.meta.url))}` +) + +export const fixedPool = new FixedThreadPool( + availableParallelism(), + workerFile, { - errorHandler: e => console.error(e), - onlineHandler: () => console.log('Worker is online') + errorHandler: (e: Error) => { + console.error(e) + }, + onlineHandler: () => { + console.info('Worker is online') + } } ) -export const dynamicPool = new DynamicThreadPool>( - 2, - 8, - join(__dirname, 'worker.js'), +export const dynamicPool = new DynamicThreadPool( + Math.floor(availableParallelism() / 2), + availableParallelism(), + workerFile, { - errorHandler: e => console.error(e), - onlineHandler: () => console.log('Worker is online') + errorHandler: (e: Error) => { + console.error(e) + }, + onlineHandler: () => { + console.info('Worker is online') + } } ) + +// eslint-disable-next-line @typescript-eslint/no-misused-promises +setTimeout(async () => { + await fixedPool.destroy() + await dynamicPool.destroy() +}, 3000)