54 releases

new 0.2.1 Jan 10, 2025
0.1.16 Dec 20, 2024
0.1.15 Sep 27, 2024
0.1.6 Jul 30, 2024
0.0.6 Mar 31, 2023

#554 in Network programming

Download history 237/week @ 2024-09-14 289/week @ 2024-09-21 83/week @ 2024-09-28 12/week @ 2024-10-05 14/week @ 2024-10-12 7/week @ 2024-10-19 2/week @ 2024-10-26 12/week @ 2024-11-02 2/week @ 2024-11-09 8/week @ 2024-11-16 8/week @ 2024-11-23 4/week @ 2024-11-30 17/week @ 2024-12-07 99/week @ 2024-12-14 45/week @ 2024-12-21

161 downloads per month
Used in 4 crates

MIT license

74KB
1.5K SLoC

crates.io Documentation CI Coverage License

general-mq

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

  • AMQP 0-9-1
  • MQTT

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

  • Unicast or broadcast.
  • Reliable or best-effort.

Notes

  • MQTT uses shared queues to implement unicast.
  • AMQP uses confirm channels to implement reliable publish, and MQTT uses QoS 1 to implement reliable publish/subscribe.

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:

  • The AMQP implementation uses one Channel for one queue, so the program can manages all queues with one connection.
  • The MQTT implementation MUST uses one connection for one queue, or both sender and receiver will receive packets.

Test

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

  • To install using Docker:

    $ docker run --rm --name rabbitmq -d -p 5672:5672 rabbitmq:management-alpine
    $ docker run --rm --name emqx -d -p 1883:1883 emqx/emqx
    

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

Dependencies

~23–36MB
~676K SLoC