Skip to content
This repository has been archived by the owner on Nov 23, 2022. It is now read-only.

A wrapper over async queue helpful in managing the queue length and reducing memory usage during batch jobs.

License

Notifications You must be signed in to change notification settings

kartik1998/async-queue-manager

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

async-queue-manager

A wrapper over async queue helpful in managing the queue length

Usage example

// inputArray of huge length (approx 1000 or more)
const lowWaterMark = 40; // whatever you want it to be
const highWaterMark = 100; // whatever you want it to be

function main(inputArray) {
  const queue = async.queue(worker, 20);
  async function worker(input, cb) {
    console.log("queue length -->", queue.length());
    if (queue.length() <= lowWaterMark) queueManager.resume();
    await doSomething(input);
    return cb();
  }
  const queueManager = new QueueManager(queue);
  for (const input of inputArray) {
    if (queue.length() >= highWaterMark) await queueManager.pause(); // pauses the loop till queue length has decreased below low watermark
    queue.push(input);
  }
}

When should you use it?

Let's say that you have to load a huge csv file from disk or maybe s3 into memory, convert it into json chunks and do some procesing over it. If you're using (for example) a micro instance (which may already have some heavy processes running) then you only have limited amount of memory and after loading the entire csv file into memory you don't want your queue to use too much memory too. This is where queue manager helps you in pausing and waiting for your queue to clear up a bit before you start loading it again.

License

MIT

About

A wrapper over async queue helpful in managing the queue length and reducing memory usage during batch jobs.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published