yakugen (yaku-gen) is a dynamic promise executor for Node.js. yakugen dynamically adjusts Promise concurrency to maintain stability while maximizing performance by meeting target CPU, Event Loop Utilization and user-defined metrics.
API Reference: https://ragrag.github.io/yakugen
npm install yakugen
async function asyncTask(item){
await doSomething(item);
}
const items = new Array(1000).fill(Math.random());
const tasks = items.map(it => async () => {
return asyncTask(it);
});
const resAll = await Yakugen.all(tasks);
const resAllSettled = await Yakugen.allSettled(tasks);
async function asyncTask(item){
await doSomething(item);
}
const items = new Array(1000).fill(Math.random());
const tasks = items.map(it => async () => {
return asyncTask(it);
});
const res = await Yakugen.all(tasks, { minConcurrency: 5, maxConcurrency: 50 });
Yakugen defaults:
minConcurrency
: 1maxConcurrency
: 500
async function asyncTask(item){
await doSomething(item);
}
const items = new Array(1000).fill(Math.random());
const tasks = items.map(it => async () => {
return asyncTask(it);
});
const res = await Yakugen.all(tasks, { targets: { cpuUtilization: 60, eventLoopUtilization: 65, eventLoopDelayMs: 100 } });
Yakugen defaults:
cpuUtilization
: 75eventLoopUtilization
: 75eventLoopDelayMs
: 150
async function asyncTask(item){
await doSomething(item);
}
const items = new Array(1000).fill(Math.random());
const tasks = items.map(it => async () => {
return asyncTask(it);
});
const res = await Yakugen.all(tasks, {
targets: {
custom: {
connectionPool: {
current: () => db.currentConnections(),
target: db.poolSize() / 2,
},
// ... add more custom metrics
},
},
});
In addition to cpuUtilization
, eventLoopUtilization
, eventLoopDelayMs
Yakugen will also adjust concurrency based on provided custom metrics.
async function asyncTask(item){
await doSomething(item);
}
const items = new Array(1000).fill(Math.random());
const tasks = items.map(it => async () => {
return asyncTask(it);
});
const res = await Yakugen.all(tasks, {
onProgress: (processed, metrics, currentConcurrency) => {
console.log(processed, metrics, currentConcurrency);
},
});