docs: update benchmarks vs. external pools
[poolifier.git] / examples / dynamicExample.js
... / ...
CommitLineData
1const {
2 DynamicThreadPool,
3 PoolEvents,
4 availableParallelism
5} = require('poolifier')
6
7const pool = new DynamicThreadPool(
8 Math.floor(availableParallelism() / 2),
9 availableParallelism(),
10 './yourWorker.js',
11 {
12 errorHandler: e => console.error(e),
13 onlineHandler: () => console.info('worker is online')
14 }
15)
16let poolFull = 0
17let poolBusy = 0
18pool.emitter.on(PoolEvents.full, () => poolFull++)
19pool.emitter.on(PoolEvents.busy, () => poolBusy++)
20
21let resolved = 0
22const start = performance.now()
23const iterations = 1000
24for (let i = 1; i <= iterations; i++) {
25 pool
26 .execute({})
27 .then(() => {
28 resolved++
29 if (resolved === iterations) {
30 console.info('Time taken is ' + (performance.now() - start))
31 console.info('The pool was full for ' + poolFull + ' times')
32 return console.info('The pool was busy for ' + poolBusy + ' times')
33 }
34 return null
35 })
36 .catch(err => console.error(err))
37}