next-webworker-pool
data:image/s3,"s3://crabby-images/ab3fb/ab3fb51dd121bf313fa145eb9a8755430adc943b" alt=".github/workflows/publish.yaml"
A NPM package that enables developers to build Web Worker pools for Next.js applications.
Installation
npm install next-webworker-pool
Usage
1. Create a Web Worker file
This is the file that will be run inside the Web Worker.
import type { WebWorkerTask, WebWorkerResult } from 'next-webworker-pool';
type MyInput = number;
type MyOutput = number;
self.onmessage = function (e: MessageEvent<WebWorkerTask<MyInput, MyOutput>>) {
self.postMessage(runTask(e.data));
};
function runTask(
task: WebWorkerTask<MyInput, MyOutput>,
): WebWorkerResult<MyInput> {
const result = task.data + 1;
return {
id: task.id,
data: result,
};
}
2. Create a Web Worker pool by extending the WebWorkerPool
class or use the factory function
This is a class that is responsible for creating Web Workers from a specific source, and running tasks on them.
This pattern is used, because Next.js scans the source code for new Worker(new URL(...))
calls, and replaces
them with the Next.js custom bundling implementation.
Using the factory function
import { createWebWorkerPool } from 'next-webworker-pool';
import type { MyInput, MyOutput } from './my-worker';
export const myWorkerPool = createWebWorkerPool<MyInput, MyOutput>(
new URL('./my-worker.ts', import.meta.url),
{ maxWorkers: 4 },
);
The worker pool can then be used directly in your Next.js application:
import { myWorkerPool } from '../my-worker-pool';
export default function Home() {
const [result, setResult] = useState<number | null>(null);
useEffect(() => {
const task = myWorkerPool.executeTask(1);
task.promise
.then((result) => {
setResult(result);
})
.catch((error) => {
console.error(error);
});
return () => {
myWorkerPool.terminate();
};
}, []);
return <div>{result}</div>;
}
Extending the WebWorkerPool
class
import { WebWorkerPool } from 'next-webworker-pool';
import type { MyInput, MyOutput } from './my-worker';
export class MyWorkerPool extends WebWorkerPool<MyInput, MyOutput> {
_createWorker(): Worker {
return new Worker(new URL('./my-worker.ts', import.meta.url));
}
}
To use the Web Worker pool, you need to create an instance of it, and call the run
method with the input data.
import { MyWorkerPool } from '../my-worker-pool';
export default function Home() {
const [result, setResult] = useState<number | null>(null);
useEffect(() => {
const pool = new MyWorkerPool();
const task = pool.executeTask(1);
task.promise
.then((result) => {
setResult(result);
})
.catch((error) => {
console.error(error);
});
return () => {
pool.terminate();
};
}, []);
return <div>{result}</div>;
}
Options
maxWorkers
The maximum number of Web Workers that can be created by the pool. Defaults to navigator.hardwareConcurrency
or 4 if hardwareConcurrency
is not supported.
export class MyWorkerPool extends WebWorkerPool<MyInput, MyOutput> {
constructor() {
super({
maxWorkers: 4,
});
}
createWorker(): Worker {
return new Worker(new URL('./my-worker.ts', import.meta.url));
}
}