bullmq vs bull vs agenda vs kue vs bee-queue
Node.js Job Queue Libraries Comparison
1 Year
bullmqbullagendakuebee-queueSimilar Packages:
What's Node.js Job Queue Libraries?

Job queue libraries are essential for managing background tasks in Node.js applications. They allow developers to offload time-consuming operations from the main application thread, improving responsiveness and scalability. These libraries provide features for scheduling, prioritizing, and processing jobs asynchronously, which is crucial for applications that require handling large volumes of tasks or need to perform operations at specific times.

Package Weekly Downloads Trend
Github Stars Ranking
Stat Detail
Package
Downloads
Stars
Size
Issues
Publish
License
bullmq1,021,6726,6231.99 MB2852 days agoMIT
bull906,75415,802309 kB1502 months agoMIT
agenda124,9099,478353 kB350-MIT
kue23,7439,459-2878 years agoMIT
bee-queue20,3273,895106 kB46a year agoMIT
Feature Comparison: bullmq vs bull vs agenda vs kue vs bee-queue

Job Scheduling

  • bullmq:

    BullMQ enhances job scheduling with a more advanced API, allowing for delayed jobs, repeatable jobs, and job dependencies. It is designed for applications that require sophisticated scheduling and job management features.

  • bull:

    Bull offers powerful job scheduling capabilities, including delayed jobs and job retries. It allows developers to set specific timestamps for job execution and provides options for handling failed jobs, making it ideal for complex job workflows.

  • agenda:

    Agenda provides a simple API for scheduling jobs with support for recurring jobs using cron syntax. It allows developers to define jobs that can run at specific intervals or times, making it easy to manage scheduled tasks in a Node.js application.

  • kue:

    Kue allows for job scheduling but is primarily focused on job processing. It provides a simple way to create delayed jobs and supports job retries, making it suitable for applications that need to manage job execution timing.

  • bee-queue:

    Bee-Queue focuses on fast job processing and does not inherently support scheduling. Instead, it is designed for immediate job processing as they are added to the queue, making it suitable for real-time applications where jobs need to be executed as soon as possible.

Performance

  • bullmq:

    BullMQ improves upon Bull's performance with a more modular architecture, allowing for better scaling and resource management. It is designed for modern applications that require high performance and flexibility in job processing.

  • bull:

    Bull is built for performance and can handle a large number of jobs efficiently. It uses Redis for job storage, which allows for fast access and processing, making it suitable for high-throughput applications.

  • agenda:

    Agenda is optimized for simplicity and ease of use, but it may not perform as well as other libraries under heavy load due to its reliance on MongoDB for job storage. It is best suited for applications with moderate job processing needs.

  • kue:

    Kue provides decent performance but may not match the speed of Bull or Bee-Queue. It is best suited for applications that benefit from its UI and monitoring capabilities rather than raw performance.

  • bee-queue:

    Bee-Queue is designed for high performance and low latency, making it one of the fastest job queues available. It is optimized for processing jobs quickly and efficiently, making it ideal for applications that require rapid job execution.

User Interface

  • bullmq:

    BullMQ offers an improved web interface over Bull, providing better visualization and management of job queues, making it easier for developers to monitor and control job processing.

  • bull:

    Bull includes a simple web interface for monitoring job statuses, allowing developers to visualize job queues and their progress. This feature is useful for debugging and managing job processing.

  • agenda:

    Agenda does not include a built-in user interface for monitoring jobs. Developers need to implement their own monitoring solutions if they require visibility into job processing.

  • kue:

    Kue comes with a built-in UI that allows developers to monitor jobs, view their statuses, and manage job processing visually. This feature is particularly useful for applications that require hands-on job management.

  • bee-queue:

    Bee-Queue does not provide a user interface, focusing instead on performance and simplicity. Developers can build their own monitoring tools if needed.

Extensibility

  • bullmq:

    BullMQ is highly extensible, allowing developers to create custom job types and integrate with other systems easily. Its modular architecture supports a wide range of use cases and customizations.

  • bull:

    Bull provides a flexible API that allows developers to extend its functionality, including job processing and event handling. This makes it suitable for applications that need to integrate with other systems or require custom job processing logic.

  • agenda:

    Agenda is extensible through its plugin system, allowing developers to create custom job types and extend its functionality as needed. This makes it suitable for applications that require specific job handling capabilities.

  • kue:

    Kue allows for some level of extensibility, enabling developers to create custom job types and manage job processing. However, it may not be as flexible as Bull or BullMQ for complex integrations.

  • bee-queue:

    Bee-Queue is designed to be lightweight and does not offer extensive extensibility options. It is best suited for applications that do not require complex customizations.

Learning Curve

  • bullmq:

    BullMQ has a steeper learning curve than Bull due to its more complex architecture and additional features. Developers may need to invest time in understanding its modular design and advanced job management capabilities.

  • bull:

    Bull has a moderate learning curve, as it offers more features and options compared to simpler libraries. Developers may need to spend some time understanding its advanced capabilities.

  • agenda:

    Agenda has a gentle learning curve due to its simplicity and straightforward API. Developers can quickly get started with scheduling jobs without a steep learning curve.

  • kue:

    Kue is relatively easy to learn, especially for developers familiar with Node.js. Its API is straightforward, but the lack of advanced features may limit its use in more complex applications.

  • bee-queue:

    Bee-Queue's API is simple and easy to understand, making it accessible for developers who need a fast job queue without extensive setup or configuration.

How to Choose: bullmq vs bull vs agenda vs kue vs bee-queue
  • bullmq:

    Choose BullMQ if you want to leverage the latest features and improvements over Bull, including a more modular architecture and better support for TypeScript. It is designed for modern applications that require advanced job management and scalability.

  • bull:

    Opt for Bull if you need a robust and feature-rich job queue with advanced capabilities such as job prioritization, delayed jobs, and rate limiting. It is a good choice for applications that require a high level of control over job processing and need to handle complex workflows.

  • agenda:

    Choose Agenda if you need a simple, MongoDB-backed job scheduler that is easy to set up and use. It is ideal for applications that require recurring jobs and offers a straightforward API for scheduling tasks with a focus on simplicity.

  • kue:

    Select Kue if you need a job queue with a built-in UI for monitoring jobs and their statuses. It is suitable for applications that benefit from visualizing job processing and require a more hands-on approach to job management.

  • bee-queue:

    Select Bee-Queue if you are looking for a lightweight, fast job queue that is optimized for performance. It is suitable for applications that need to process jobs quickly and efficiently, especially in scenarios where Redis is already in use.

README for bullmq



The fastest, most reliable, Redis-based distributed queue for Node.
Carefully written for rock solid stability and atomicity.

Read the documentation

Follow @manast for *important* Bull/BullMQ/BullMQ-Pro news and updates!

🛠 Tutorials

You can find tutorials and news in this blog: https://blog.taskforce.sh/

News 🚀

🌐 Language agnostic BullMQ

Do you need to work with BullMQ on platforms other than Node.js? If so, check out the BullMQ Proxy

Official FrontEnd

Taskforce.sh, Inc

Supercharge your queues with a professional front end:

  • Get a complete overview of all your queues.
  • Inspect jobs, search, retry, or promote delayed jobs.
  • Metrics and statistics.
  • and many more features.

Sign up at Taskforce.sh

🚀 Sponsors 🚀

Dragonfly Dragonfly is a new Redis™ drop-in replacement that is fully compatible with BullMQ and brings some important advantages over Redis™ such as massive better performance by utilizing all CPU cores available and faster and more memory efficient data structures. Read more here on how to use it with BullMQ.

Used by

Some notable organizations using BullMQ:

Microsoft Vendure Datawrapper Nest
Curri Novu NoCodeDB Infisical

The gist

Install:

$ yarn add bullmq

Add jobs to the queue:

import { Queue } from 'bullmq';

const queue = new Queue('Paint');

queue.add('cars', { color: 'blue' });

Process the jobs in your workers:

import { Worker } from 'bullmq';

const worker = new Worker('Paint', async job => {
  if (job.name === 'cars') {
    await paintCar(job.data.color);
  }
});

Listen to jobs for completion:

import { QueueEvents } from 'bullmq';

const queueEvents = new QueueEvents('Paint');

queueEvents.on('completed', ({ jobId }) => {
  console.log('done painting');
});

queueEvents.on(
  'failed',
  ({ jobId, failedReason }: { jobId: string; failedReason: string }) => {
    console.error('error painting', failedReason);
  },
);

This is just scratching the surface, check all the features and more in the official documentation

Feature Comparison

Since there are a few job queue solutions, here is a table comparing them:

| Feature | BullMQ-Pro | BullMQ | Bull | Kue | Bee | Agenda | | :------------------------ | :-----------------------------------------: | :-------------------------: | :-------------: | :---: | -------- | ------ | | Backend | redis | redis | redis | redis | redis | mongo | | Observables | ✓ | | | | | | | Group Rate Limit | ✓ | | | | | | | Group Support | ✓ | | | | | | | Batches Support | ✓ | | | | | | | Parent/Child Dependencies | ✓ | ✓ | | | | | | Debouncing | ✓ | ✓ | ✓ | | | | | Priorities | ✓ | ✓ | ✓ | ✓ | | ✓ | | Concurrency | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | | Delayed jobs | ✓ | ✓ | ✓ | ✓ | | ✓ | | Global events | ✓ | ✓ | ✓ | ✓ | | | | Rate Limiter | ✓ | ✓ | ✓ | | | | | Pause/Resume | ✓ | ✓ | ✓ | ✓ | | | | Sandboxed worker | ✓ | ✓ | ✓ | | | | | Repeatable jobs | ✓ | ✓ | ✓ | | | ✓ | | Atomic ops | ✓ | ✓ | ✓ | | ✓ | | | Persistence | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | | UI | ✓ | ✓ | ✓ | ✓ | | ✓ | | Optimized for | Jobs / Messages | Jobs / Messages | Jobs / Messages | Jobs | Messages | Jobs |

Contributing

Fork the repo, make some changes, submit a pull-request! Here is the contributing doc that has more details.

Thanks

Thanks for all the contributors that made this library possible, also a special mention to Leon van Kammen that kindly donated his npm bullmq repo.