RabbitMQ is an open-source
message-broker software (sometimes called
message-oriented middleware
Message-oriented middleware (MOM) is software or hardware infrastructure supporting sending and receiving messages between distributed systems. Message-oriented middleware is in contrast to streaming-oriented middleware where data is communicate ...
) that originally implemented the
Advanced Message Queuing Protocol (AMQP) and has since been extended with a
plug-in architecture to support
Streaming Text Oriented Messaging Protocol (STOMP),
MQ Telemetry Transport (MQTT), and other protocols.
Written in
Erlang, the RabbitMQ server is built on the
Open Telecom Platform framework for clustering and failover. Client libraries to interface with the broker are available for all major programming languages. The source code is released under the
Mozilla Public License.
Since November 2020, there are commercial offerings available of RabbitMQ, for support and enterprise features: "VMware RabbitMQ OVA", "VMware RabbitMQ" and "VMware RabbitMQ for Kubernetes" (different feature levels) Open-Source RabbitMQ is also packaged by
Bitnami and commercially for VMware's Tanzu Application Service.
History
Originally developed by Rabbit Technologies Ltd. which started as a joint venture between LShift and CohesiveFT in 2007, RabbitMQ was acquired in April 2010 by
SpringSource, a division of
VMware. The project became part of
Pivotal Software in May 2013. Which then got acquired back by VMware in December 2019.
The project consists of:
*The RabbitMQ exchange server
*Gateways for
AMQP,
HTTP
HTTP (Hypertext Transfer Protocol) is an application layer protocol in the Internet protocol suite model for distributed, collaborative, hypermedia information systems. HTTP is the foundation of data communication for the World Wide Web, wher ...
,
STOMP, and
MQTT protocols
*
AMQP client libraries for
Java
Java is one of the Greater Sunda Islands in Indonesia. It is bordered by the Indian Ocean to the south and the Java Sea (a part of Pacific Ocean) to the north. With a population of 156.9 million people (including Madura) in mid 2024, proje ...
,
.NET Framework and Erlang. (AMQP clients for other languages are available from other vendors.)
*A plug-in platform for extensibility, with a predefined collection of supported plug-ins, including:
**A "Shovel" plug-in that takes care of moving or copying (replicating) messages from one broker to another.
**A "Federation" plug-in that enables efficient sharing of messages between brokers (at the exchange level).
**A "Management" plug-in that enables monitoring and control of brokers and clusters of brokers.
Examples
This section gives sample programs written in
Python (using the ''pika'' package) for sending and receiving messages using a queue.
Sending
The following code fragment establishes a connection, makes sure the recipient queue exists, then sends a message and finally closes the connection.
#!/usr/bin/env python3
import pika
connection = pika.BlockingConnection(pika.ConnectionParameters(host="localhost"))
channel = connection.channel()
channel.queue_declare(queue="hello")
channel.basic_publish(exchange="", routing_key="hello", body="Hello World!")
print(" Sent 'Hello World!'")
connection.close()
Receiving
Similarly, the following program receives messages from the queue and prints them on the screen:
(Note: This example does no
acknowledgereceipt of the message.)
#!/usr/bin/env python3
import pika
def callback(ch, method, properties, body):
print(" Received %r" % body)
connection = pika.BlockingConnection(pika.ConnectionParameters(host="localhost"))
channel = connection.channel()
channel.queue_declare(queue="hello")
print(" Waiting for messages. To exit press Ctrl+C")
channel.basic_consume(queue="hello", on_message_callback=callback)
channel.start_consuming()
See also
*
Apache Kafka
References
Further reading
*
*
*
External links
*
{{Message-oriented middleware
Erlang (programming language)
Free software programmed in Erlang
Message-oriented middleware
Software using the Mozilla Public License
Pivotal Software