-
Notifications
You must be signed in to change notification settings - Fork 64
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs: update logo, improve content readability
- Loading branch information
Showing
105 changed files
with
2,267 additions
and
1,024 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,142 +1,74 @@ | ||
> [!IMPORTANT] | ||
> Currently, RedisSMQ is going under heavy development. Pre-releases at any time may introduce new commits with breaking changes. | ||
> The master branch always reflects the most recent changes. To view the latest release reference see [RedisSMQ v7.2.3](https://github.com/weyoss/redis-smq/tree/v7.2.3) | ||
[data:image/s3,"s3://crabby-images/17180/17180967cb48b37d7a989960d3f1870a0b4de582" alt="RedisSMQ"](https://github.com/weyoss/redis-smq) | ||
|
||
<div align="center" style="text-align: center"> | ||
<p><a href="https://github.com/weyoss/redis-smq"><img alt="RedisSMQ" src="./logo.png?v=202312182134" /></a></p> | ||
<p>A simple high-performance Redis message queue for Node.js.</p> | ||
<p> | ||
<a href="https://github.com/weyoss/redis-smq/actions/workflows/tests.yml"><img src="https://github.com/weyoss/redis-smq/actions/workflows/tests.yml/badge.svg" alt="Tests" style="max-width:100%;" /></a> | ||
<a href="https://github.com/weyoss/redis-smq/actions/workflows/codeql.yml" rel="nofollow"><img src="https://github.com/weyoss/redis-smq/actions/workflows/codeql.yml/badge.svg" alt="Code quality" /></a> | ||
<a href="https://codecov.io/github/weyoss/redis-smq?branch=master" rel="nofollow"><img src="https://img.shields.io/codecov/c/github/weyoss/redis-smq" alt="Coverage Status" /></a> | ||
<a href="https://npmjs.org/package/redis-smq" rel="nofollow"><img src="https://img.shields.io/npm/v/redis-smq.svg" alt="NPM version" /></a> | ||
<a href="https://npmjs.org/package/redis-smq" rel="nofollow"><img src="https://img.shields.io/npm/dm/redis-smq.svg" alt="NPM downloads" /></a> | ||
</p> | ||
</div> | ||
A High-Performance Redis Simple Message Queue for Node.js | ||
|
||
# RedisSMQ | ||
[data:image/s3,"s3://crabby-images/c980b/c980b06c213e84b2c80cccbb61f82a1d3f704ef8" alt="Build"](https://github.com/weyoss/redis-smq/actions/workflows/tests.yml) | ||
[data:image/s3,"s3://crabby-images/325c5/325c53baff7d54ddbaf01e6a47c8b74b8dedfac5" alt="Code Quality"](https://github.com/weyoss/redis-smq/actions/workflows/codeql.yml) | ||
[data:image/s3,"s3://crabby-images/92308/923081cc682e6687f2108a43ce49c005e503995b" alt="Code Coverage"](https://codecov.io/github/weyoss/redis-smq?branch=master) | ||
[data:image/s3,"s3://crabby-images/fb6c1/fb6c146219392adc274ee10468c5b73f7b01c175" alt="Latest Release"](https://github.com/weyoss/redis-smq/releases) | ||
data:image/s3,"s3://crabby-images/3f3ca/3f3cab6bf1294380ebefff9399f092c6d7afaa0c" alt="Downloads" | ||
|
||
RedisSMQ is a Node.js library for queuing messages (aka jobs) and processing them asynchronously with consumers. Backed by Redis, it allows scaling up your typical applications with ease of use. | ||
**Key Features** | ||
|
||
## Features | ||
* [High-performance message processing](docs/performance.md) | ||
* [Flexible producer/consumer model with multi-queue producers and consumers](docs/consuming-messages.md) | ||
* [Different exchange types (Direct, Topic, FanOut) for publishing messages to one or multiple queues](docs/message-exchanges.md) | ||
* [Two delivery models (Point-2-Point and Pub/Sub)](docs/queue-delivery-models.md) with reliable delivery and configurable retry modes | ||
* [Three queuing strategies (FIFO, LIFO, Priority Queues)](docs/queues.md) | ||
* [Message handler worker threads for sandboxing and performance improvement](docs/message-handler-worker-threads.md) | ||
* [Message expiration and consumption timeout](docs/messages.md) | ||
* [Queue rate limiting for controlling message consumption rates](docs/queue-rate-limiting.md) | ||
* [Built-in scheduler for delayed message delivery and repeating messages](docs/scheduling-messages.md) | ||
* [RESTful API](https://github.com/weyoss/redis-smq-rest-api) and web UI for interacting with the message queue | ||
* [Support for ESM and CJS modules](docs/esm-cjs-modules.md) | ||
|
||
* [High-performance message processing](docs/performance.md). | ||
* Flexible Producer/Consumer model which offers [Multi-Queue Producers](docs/producing-messages.md) & [Multi-Queue Consumers](docs/consuming-messages.md). | ||
* RedisSMQ offers different exchange types: [Direct Exchange](docs/message-exchanges.md#direct-exchange), [Topic Exchange](docs/message-exchanges.md#topic-exchange), and [FanOut Exchange](docs/message-exchanges.md#fanout-exchange) for publishing a message to one or multiple queues. | ||
* Supports [Point-2-Point](docs/queue-delivery-models.md#point-2-point-delivery-model) and [Pub/Sub](docs/queue-delivery-models.md#pubsub-delivery-model) [delivery models](docs/queue-delivery-models.md). | ||
* Both [delivery models](docs/queue-delivery-models.md) are reliable. For cases of failure, while delivering/consuming messages, [at-least-once](docs/api/classes/ProducibleMessage.md#setretrythreshold) and [at-most-once](docs/api/classes/ProducibleMessage.md#setretrythreshold) modes may be configured. | ||
* [3 queuing strategies](docs/queues.md): [FIFO queues](docs/queues.md#fifo-first-in-first-out-queues), [LIFO queues](docs/queues.md#lifo-last-in-first-out-queues), and [Priority Queues](docs/queues.md#priority-queues). | ||
* [Message Handler Worker Threads](docs/message-handler-worker-threads.md) which allow sandboxing and running your message handler from a separate isolated thread and without affecting the performance of other message handlers from the same consumer. | ||
* Messages can be [set to expire](docs/api/classes/ProducibleMessage.md#setttl) when not delivered within a given amount of time or to have a [consumption timeout](docs/api/classes/ProducibleMessage.md#setconsumetimeout) while being in process. | ||
* Queues may be [rate Limited](docs/queue-rate-limiting.md) to control the rate at which the messages are consumed. | ||
* Has a builtin [scheduler](docs/scheduling-messages.md) allowing messages [to be delayed](docs/api/classes/ProducibleMessage.md#setscheduleddelay), [to be delivered for N times](docs/api/classes/ProducibleMessage.md#setscheduledrepeat) with an optional [period between deliveries](docs/api/classes/ProducibleMessage.md#setscheduledrepeatperiod), or simply [to be scheduled using CRON expressions](docs/api/classes/ProducibleMessage.md#setscheduledcron). | ||
* Provides [an HTTP interface](https://github.com/weyoss/redis-smq-rest-api) to interact with the message queue using a RESTful API. | ||
* RedisSMQ can be managed also from your [web browser](https://github.com/weyoss/redis-smq-monitor-client). | ||
* Either [node-redis](https://github.com/redis/node-redis) or [ioredis](https://github.com/luin/ioredis) can be used as a Redis client. | ||
* [Highly optimized](https://lgtm.com/projects/g/weyoss/redis-smq/context:javascript), implemented using pure callbacks, with small memory footprint and no memory leaks. See [Callback vs Promise vs Async/Await benchmarks](https://gist.github.com/weyoss/24f9ecbda175d943a48cb7ec38bde821). | ||
* [Both ESM & CJS modules are supported](docs/esm-cjs-modules.md). | ||
**Use Cases** | ||
|
||
## RedisSMQ Use Case: Multi-Queue Producers & Multi-Queue Consumers | ||
- Managing background tasks, such as email sending or data processing. | ||
- Efficiently scheduling and retrying tasks. | ||
- Communication between multiple services in microservices architectures. | ||
- Handling real-time events in gaming, IoT, or analytics systems. | ||
|
||
data:image/s3,"s3://crabby-images/5c828/5c828774e43ad529768733c61819a96266debb24" alt="RedisSMQ Multi-Queue Producers & Multi-Queue Consumers" | ||
**Installation and Usage** | ||
|
||
## What's new? | ||
|
||
:rocket: RC's are now available for RedisSMQ v8! The v8 release will bring major improvements and new features. Some of them are: | ||
|
||
- [x] Message queue codebase refactoring and optimizations. | ||
- [x] Message storage and handling improvements. | ||
- [x] Message status which allows to retrieve, at any time, the status of a message by its ID. | ||
- [x] [Pub/Sub Delivery Model and Consumer Groups](docs/queue-delivery-models.md#pubsub-delivery-model). | ||
- [x] Message handlers sandboxing and message processing performance improvement with [Message Handler Worker Threads](docs/message-handler-worker-threads.md). | ||
- [x] Cross-system event propagation based on [EventBus](docs/event-bus.md). | ||
- [x] Better error handling aiming at reporting fatal errors to the application whenever it is possible and without crashing the main process. | ||
- [x] [ESM Modules Support](docs/esm-cjs-modules.md). | ||
|
||
Current RedisSMQ v8 RC status: | ||
|
||
- [x] RedisSMQ Common Library | ||
- [x] RedisSMQ | ||
- [x] [RESTful API](https://github.com/weyoss/redis-smq-rest-api) | ||
- [ ] Web UI (WIP) | ||
|
||
If you wish to get the latest updates early feel free to try RedisSMQ v8 RC. Do not hesitate to report any bug or issue if encountered. | ||
|
||
Otherwise, stay with [RedisSMQ v7](https://github.com/weyoss/redis-smq/tree/v7.2.3) if you are looking for a fully working release with an HTTP API and a Web UI. | ||
|
||
## Installation | ||
|
||
```shell | ||
To get started with RedisSMQ, you can install the library using npm: | ||
```bash | ||
npm i redis-smq@rc | ||
``` | ||
|
||
Considerations: | ||
|
||
- Minimal Node.js version is >= 18 (RedisSMQ is tested under current active LTS and maintenance LTS Node.js releases). | ||
- Minimal Redis server version is 4.0.0. | ||
|
||
## Usage | ||
|
||
RedisSMQ provides 3 classes in order to work with the message queue: `ProducibleMessage`, `Producer`, and `Consumer`. | ||
|
||
Producers and consumers exchange data using one or multiple queues that may be created using the [Queue Class](docs/api/classes/Queue.md). | ||
|
||
A queue is responsible for holding messages which are produced by producers and are delivered to consumers. | ||
|
||
### Creating a queue | ||
|
||
Create a queue, produce a message, and consume it using the provided classes and methods: | ||
```javascript | ||
// Creating a queue | ||
const queue = new Queue(); | ||
queue.save( | ||
'my_queue', | ||
EQueueType.LIFO_QUEUE, | ||
EQueueDeliveryModel.POINT_TO_POINT, | ||
(err) => { | ||
queue.save('my_queue', EQueueType.LIFO_QUEUE, EQueueDeliveryModel.POINT_TO_POINT, (err) => { | ||
if (err) console.error(err); | ||
}, | ||
); | ||
``` | ||
|
||
In the example above we are defining a [LIFO queue](docs/queues.md#lifo-last-in-first-out-queues) with a [POINT-2-POINT delivery model](docs/queue-delivery-models.md#point-2-point-delivery-model). | ||
|
||
See [Queues](docs/queues.md) for more details. | ||
|
||
### Producing a message | ||
}); | ||
|
||
```javascript | ||
// Producing a message | ||
const msg = new ProducibleMessage(); | ||
msg.setQueue('my_queue').setBody('Hello Word!'); | ||
producer.produce(msg, (err, ids) => { | ||
if (err) console.error(err); | ||
else console.log(`Produced message IDs are: ${ids.join(', ')}`); | ||
if (err) console.error(err); | ||
else console.log(`Produced message IDs are: ${ids.join(', ')}`); | ||
}); | ||
``` | ||
|
||
See [Producing Messages](docs/producing-messages.md) for more details. | ||
|
||
### Consuming a message | ||
|
||
```javascript | ||
// Consuming a message | ||
const consumer = new Consumer(); | ||
const messageHandler = (msg, cb) => { | ||
console.log(msg.body); | ||
cb(); | ||
console.log(msg.body); | ||
cb(); // Acknowledging | ||
}; | ||
consumer.consume('my_queue', messageHandler, (err) => { | ||
if (err) console.error(err); | ||
if (err) console.error(err); | ||
}); | ||
``` | ||
**Documentation** | ||
|
||
See [Consuming Messages](docs/consuming-messages.md) for more details. | ||
|
||
## Documentation | ||
|
||
See [RedisSMQ Docs](docs/README.md) for more details. | ||
For more information, visit the [RedisSMQ Docs](docs/README.md). | ||
|
||
## Contributing | ||
**Contributing** | ||
|
||
So you are interested in contributing to this project? Please see [CONTRIBUTING.md](https://github.com/weyoss/guidelines/blob/master/CONTRIBUTIONS.md). | ||
Interested in contributing to this project? Please check out our [CONTRIBUTING.md](https://github.com/weyoss/guidelines/blob/master/CONTRIBUTIONS.md). | ||
|
||
## License | ||
**License** | ||
|
||
[MIT](https://github.com/weyoss/redis-smq/blob/master/LICENSE) | ||
RedisSMQ is released under the [MIT License](https://github.com/weyoss/redis-smq/blob/master/LICENSE). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,29 +1,35 @@ | ||
[RedisSMQ](../README.md) / Docs | ||
|
||
# RedisSMQ Docs | ||
# RedisSMQ Documentation | ||
|
||
Welcome to the RedisSMQ documentation hub! Here, you'll find all the information you need to work with RedisSMQ effectively. | ||
|
||
## API Reference | ||
|
||
See [API Reference](api/README.md) for more details. | ||
For detailed information about the available API endpoints and their functionalities, please refer to the [API Reference](api/README.md). | ||
|
||
## Getting Started | ||
|
||
- [Configuration](configuration.md) | ||
- [Queues](queues.md) | ||
- [Queue Delivery Models](queue-delivery-models.md) | ||
- [Producing Messages](producing-messages.md) | ||
- [Consuming Messages](consuming-messages.md) | ||
- [Messages](messages.md) | ||
- [Message Exchanges](message-exchanges.md) | ||
- [Queue Rate Limiting](queue-rate-limiting.md) | ||
- [Exchanges and Delivery Models](exchanges-and-delivery-models.md) | ||
- [Scheduling Messages](scheduling-messages.md) | ||
- [Message Handler Worker Threads](message-handler-worker-threads.md) | ||
- [EventBus](event-bus.md) | ||
- [Multiplexing](multiplexing.md) | ||
- [Performance](performance.md) | ||
- [RedisSMQ Architecture](redis-smq-architecture.md) | ||
- [Logs](https://github.com/weyoss/redis-smq-common/blob/master/docs/README.md#logs) | ||
- [HTTP API](https://github.com/weyoss/redis-smq-monitor) | ||
- [Web UI](https://github.com/weyoss/redis-smq-monitor-client) | ||
- [ESM & CJS Modules](esm-cjs-modules.md) | ||
To help you get up and running with RedisSMQ, we’ve organized essential resources into the following categories: | ||
|
||
- **[Configuration](configuration.md)**: Learn how to configure RedisSMQ for your specific needs. | ||
- **[Queues](queues.md)**: Understand how to create and manage queues to process messages. | ||
- **[Queue Delivery Models](queue-delivery-models.md)**: Explore different delivery models available for your queues. | ||
- **[Producing Messages](producing-messages.md)**: Discover how to produce and send messages to your queues. | ||
- **[Consuming Messages](consuming-messages.md)**: Get insights into how to consume and process messages from your queues. | ||
- **[Messages](messages.md)**: A comprehensive overview of message handling within RedisSMQ. | ||
- **[Message Exchanges](message-exchanges.md)**: Learn about message exchange patterns and how they work in RedisSMQ. | ||
- **[Queue Rate Limiting](queue-rate-limiting.md)**: Understand how to implement rate limiting for your queues. | ||
- **[Exchanges and Delivery Models](exchanges-and-delivery-models.md)**: Delve deeper into the interplay between exchanges and delivery models. | ||
- **[Scheduling Messages](scheduling-messages.md)**: Find out how to schedule messages for future delivery. | ||
- **[Message Handler Worker Threads](message-handler-worker-threads.md)**: Learn about worker threads and how they manage message processing. | ||
- **[EventBus](event-bus.md)**: Discover the EventBus feature for event-driven architecture. | ||
- **[Multiplexing](multiplexing.md)**: Understand how to use multiplexing for improved message handling. | ||
- **[Performance](performance.md)**: Learn about the performance of RedisSMQ. | ||
- **[RedisSMQ Architecture](redis-smq-architecture.md)**: Gain insights into the architectural design of RedisSMQ. | ||
- **[Logs](https://github.com/weyoss/redis-smq-common/blob/master/docs/README.md#logs)**: Learn how to access and utilize logs for monitoring and debugging. | ||
- **[HTTP API](https://github.com/weyoss/redis-smq-monitor)**: Access the HTTP API for integrating RedisSMQ with other applications. | ||
- **[Web UI](https://github.com/weyoss/redis-smq-monitor-client)**: Explore the web interface for easy management of RedisSMQ. | ||
- **[ESM & CJS Modules](esm-cjs-modules.md)**: Find out how to work with ECMAScript Modules and CommonJS modules. | ||
|
||
We hope this documentation serves as a valuable resource as you implement and use RedisSMQ in your projects! |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.