crates.io Documentation CI Coverage License

general-mq

General purposed interfaces for message queues. Now we provide the following implementations:

By using these classes, you can configure queues with the following properties:

Notes

Relationships of Connections and Queues

The term connection describes a TCP/TLS connection to the message broker. The term queue describes a message queue or a topic within a connection. You can use one connection to manage multiple queues, or one connection to manage one queue.

A queue can only be a receiver or a sender at a time.

Connections for sender/receiver queues with the same name

The sender and the receiver are usually different programs, there are two connections to hold two queues.

For the special case that a program acts both the sender and the receiver using the same queue:

Test

Please prepare a RabbitMQ broker and a EMQX broker at localhost for testing.

Then run the test:

$ cargo test --test integration_test -- --nocapture

Example

Launch RabbitMQ and then run AMQP example:

$ cargo run --example simple

Launch EMQX and then run MQTT example:

$ RUN_MQTT= cargo run --example simple