thread-tasks
Thread Tasks: Offload your CPU-intensive tasks to separate threads.
Thread Tasks: Offload your CPU-intensive tasks to separate threads.
npm install thread-tasks
const task = {
fn: () => console.log('Hello World!')
};
threadTasks([task]);
threadTasks
threadTasksAdvanced
threadTasks
takes in an array of task objects and returns an array of workers.
Task Object: Each task object should have the following properties:
-
fn
: the function (task) to be executed. Can be a normal function or an async function. -
args
: an optional object containing arguments to be passed to the function. -
onSuccess
: an optional callback function to be executed when the function completes successfully. -
onError
: an optional callback function to be executed when the function throws an error.
const task = {
fn: () => console.log('Hello World!')
};
threadTasks([task]);
const tasks = [
{
fn: data => data.a + data.b,
args: { a: 1, b: 2 },
onSuccess: msg => console.log(`Sum = ${msg}`),
onError: err => console.log(err.message)
}
// ... other tasks to be executed in parallel ...
];
threadTasks(tasks);
const tasks = [
{
fn: async data => {
const res = await fetch(data.url);
const json = await res.json();
return json;
},
args: { url: 'https://jsonplaceholder.typicode.com/posts/1' },
onSuccess: json => console.log(JSON.stringify(json))
}
];
threadTasks(tasks);
const tasks = [
{
fn: async data => {
const axios = require('axios');
const res = await axios.get(data.url);
return res.data;
},
args: { url: 'https://jsonplaceholder.typicode.com/posts/1' },
onSuccess: data => console.log(JSON.stringify(data))
}
];
threadTasks(tasks);
threadTasksAdvanced
takes in the following properties:
-
tasks
: An array of task objects -
getMaxThreads
: An optional callback function that returns the maximum number of parallel tasks allowed to run simultaneously. -
afterAll
: An optional callback function that is executed after all of the tasks have been completed.
and returns a promise that resolves once all the tasks have been processed.
Assume listOfTasks
is a large array of tasks.
const allTasksExecuted = await threadTasksAdvanced({
tasks: listOfTasks,
getMaxThreads: () => 4,
afterAll: () => console.log('All tasks done.')
});
A maximum of 4 tasks will executing in parallel. As soon as one task finishes, another one will take its place. Until all tasks have finished execution.
const allTasksExecuted = await threadTasksAdvanced({
tasks: listOfTasks,
getMaxThreads: () => {
const { readFileSync } = require('fs');
const featureFlags = JSON.parse(readFileSync('./env.json', 'utf8'));
if (featureFlags?.USE_ALL_CORES === true) {
const { cpus } = require('os');
const cpuCount = cpus().length;
return Number(cpuCount);
}
if (featureFlags?.MAX_THREADS) {
return Number(featureFlags.MAX_THREADS);
}
return 2;
}
});
You can change values like MAX_THREADS
in env.json
while tasks are running. The updated value will take effect immediately after the file is saved, allowing you to adjust the maximum thread count (the number of tasks running simultaneously) on the fly.
- Data processing
- Image or Video processing
- Analytics
MIT License