RabbitMQ: Difference between revisions
Line 100: | Line 100: | ||
|1 year and 8 months ago |
|1 year and 8 months ago |
||
(23 Jul 2021) |
(23 Jul 2021) |
||
|Ended 2 months and 1 week ago |
|style="background: #f67e7e;"|Ended 2 months and 1 week ago |
||
(31 Jan 2023) |
(31 Jan 2023) |
||
|style="background: #f8d02e;"|Ends in 3 months and 2 weeks |
|style="background: #f8d02e;"|Ends in 3 months and 2 weeks |
||
Line 110: | Line 110: | ||
|3 years and 6 months ago |
|3 years and 6 months ago |
||
(01 Oct 2019) |
(01 Oct 2019) |
||
|Ended 8 months ago |
|style="background: #f67e7e;"|Ended 8 months ago |
||
(31 Jul 2022) |
(31 Jul 2022) |
||
|Ended 8 months ago |
|style="background: #f67e7e;"|Ended 8 months ago |
||
(31 Jul 2022) |
(31 Jul 2022) |
||
|3.8.35 |
|3.8.35 |
||
Line 119: | Line 119: | ||
|5 years ago |
|5 years ago |
||
(28 Nov 2017) |
(28 Nov 2017) |
||
|Ended 2 years and 6 months ago |
|style="background: #f67e7e;"|Ended 2 years and 6 months ago |
||
(30 Sep 2020) |
(30 Sep 2020) |
||
|Ended 2 years and 6 months ago |
|style="background: #f67e7e;"|Ended 2 years and 6 months ago |
||
(30 Sep 2020) |
(30 Sep 2020) |
||
|3.7.28 |
|3.7.28 |
||
Line 128: | Line 128: | ||
|7 years ago |
|7 years ago |
||
(22 Dec 2015) |
(22 Dec 2015) |
||
|Ended 4 years and 10 months ago |
|style="background: #f67e7e;"|Ended 4 years and 10 months ago |
||
(31 May 2018) |
(31 May 2018) |
||
|Ended 4 years and 10 months ago |
|style="background: #f67e7e;"|Ended 4 years and 10 months ago |
||
(31 May 2018) |
(31 May 2018) |
||
|3.6.16 |
|3.6.16 |
||
Line 137: | Line 137: | ||
|8 years ago |
|8 years ago |
||
(11 Mar 2015) |
(11 Mar 2015) |
||
|Ended 6 years ago |
|style="background: #f67e7e;"|Ended 6 years ago |
||
(31 Oct 2016) |
(31 Oct 2016) |
||
|Ended 6 years ago |
|style="background: #f67e7e;"|Ended 6 years ago |
||
(31 Oct 2016) |
(31 Oct 2016) |
||
|3.5.8 |
|3.5.8 |
||
Line 146: | Line 146: | ||
|8 years ago |
|8 years ago |
||
(21 Oct 2014) |
(21 Oct 2014) |
||
|Ended 7 years ago |
|style="background: #f67e7e;"|Ended 7 years ago |
||
(31 Oct 2015) |
(31 Oct 2015) |
||
|Ended 7 years ago |
|style="background: #f67e7e;"|Ended 7 years ago |
||
(31 Oct 2015) |
(31 Oct 2015) |
||
|3.4.4 |
|3.4.4 |
||
Line 155: | Line 155: | ||
|9 years ago |
|9 years ago |
||
(02 Apr 2014) |
(02 Apr 2014) |
||
|Ended 8 years ago |
|style="background: #f67e7e;"|Ended 8 years ago |
||
(31 Mar 2015) |
(31 Mar 2015) |
||
|Ended 8 years ago |
|style="background: #f67e7e;"|Ended 8 years ago |
||
(31 Mar 2015) |
(31 Mar 2015) |
||
|3.3.5 |
|3.3.5 |
||
Line 164: | Line 164: | ||
|9 years ago |
|9 years ago |
||
(23 Oct 2013) |
(23 Oct 2013) |
||
|Ended 8 years ago |
|style="background: #f67e7e;"|Ended 8 years ago |
||
(31 Oct 2014) |
(31 Oct 2014) |
||
|Ended 8 years ago |
|style="background: #f67e7e;"|Ended 8 years ago |
||
(31 Oct 2014) |
(31 Oct 2014) |
||
|3.2.4 |
|3.2.4 |
||
Line 173: | Line 173: | ||
|9 years ago |
|9 years ago |
||
(01 May 2013) |
(01 May 2013) |
||
|Ended 8 years and 11 months ago |
|style="background: #f67e7e;"|Ended 8 years and 11 months ago |
||
(30 Apr 2014) |
(30 Apr 2014) |
||
|Ended 8 years and 11 months ago |
|style="background: #f67e7e;"|Ended 8 years and 11 months ago |
||
(30 Apr 2014) |
(30 Apr 2014) |
||
|3.1.5 |
|3.1.5 |
||
Line 182: | Line 182: | ||
|10 years ago |
|10 years ago |
||
(19 Nov 2012) |
(19 Nov 2012) |
||
|Ended 9 years ago |
|style="background: #f67e7e;"|Ended 9 years ago |
||
(30 Nov 2013) |
(30 Nov 2013) |
||
|Ended 9 years ago |
|style="background: #f67e7e;"|Ended 9 years ago |
||
(30 Nov 2013) |
(30 Nov 2013) |
||
|3.0.4 |
|3.0.4 |
Revision as of 09:59, 24 April 2023
This article may rely excessively on sources too closely associated with the subject, potentially preventing the article from being verifiable and neutral. (May 2019) |
Developer(s) | VMware |
---|---|
Stable release | 3.11.13
/ March 31, 2023 |
Repository | github |
Written in | Erlang |
Operating system | Cross-platform |
Type | AMQP, message-oriented middleware |
License | Mozilla Public License |
Website | www |
RabbitMQ is an open-source message-broker software (sometimes called message-oriented middleware) 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.[1]
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.
History
Originally developed by Rabbit Technologies Ltd. which started as a joint venture between LShift and CohesiveFT in 2007,[2] RabbitMQ was acquired in April 2010 by SpringSource, a division of VMware.[3] The project became part of Pivotal Software in May 2013.[4] Which then got acquired back by VMWare in December 2019.[5]
The project consists of:
- The RabbitMQ exchange server
- Gateways for AMQP, HTTP, STOMP, and MQTT protocols
- AMQP client libraries for Java, .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(" [x] 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 not acknowledge receipt of the message.)
#!/usr/bin/env python3
import pika
def callback(ch, method, properties, body):
print(" [x] 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()
End-of-support schedule[6]
Release | Released | Community Support | Extended Support | Latest |
---|---|---|---|---|
3.11 | 6 months and 2 weeks ago
(26 Sep 2022) |
Yes | Yes | 3.11.13
(31 Mar 2023) |
3.10 | 11 months ago
(03 May 2022) |
Ends in 3 months and 2 weeks
(31 Jul 2023) |
Ends in 8 months
(30 Dec 2023) |
3.10.20
(22 Mar 2023) |
3.9 | 1 year and 8 months ago
(23 Jul 2021) |
Ended 2 months and 1 week ago
(31 Jan 2023) |
Ends in 3 months and 2 weeks
(31 Jul 2023) |
3.9.29
(09 Mar 2023) |
3.8 | 3 years and 6 months ago
(01 Oct 2019) |
Ended 8 months ago
(31 Jul 2022) |
Ended 8 months ago
(31 Jul 2022) |
3.8.35 |
3.7 | 5 years ago
(28 Nov 2017) |
Ended 2 years and 6 months ago
(30 Sep 2020) |
Ended 2 years and 6 months ago
(30 Sep 2020) |
3.7.28 |
3.6 | 7 years ago
(22 Dec 2015) |
Ended 4 years and 10 months ago
(31 May 2018) |
Ended 4 years and 10 months ago
(31 May 2018) |
3.6.16 |
3.5 | 8 years ago
(11 Mar 2015) |
Ended 6 years ago
(31 Oct 2016) |
Ended 6 years ago
(31 Oct 2016) |
3.5.8 |
3.4 | 8 years ago
(21 Oct 2014) |
Ended 7 years ago
(31 Oct 2015) |
Ended 7 years ago
(31 Oct 2015) |
3.4.4 |
3.3 | 9 years ago
(02 Apr 2014) |
Ended 8 years ago
(31 Mar 2015) |
Ended 8 years ago
(31 Mar 2015) |
3.3.5 |
3.2 | 9 years ago
(23 Oct 2013) |
Ended 8 years ago
(31 Oct 2014) |
Ended 8 years ago
(31 Oct 2014) |
3.2.4 |
3.1 | 9 years ago
(01 May 2013) |
Ended 8 years and 11 months ago
(30 Apr 2014) |
Ended 8 years and 11 months ago
(30 Apr 2014) |
3.1.5 |
3.0 | 10 years ago
(19 Nov 2012) |
Ended 9 years ago
(30 Nov 2013) |
Ended 9 years ago
(30 Nov 2013) |
3.0.4 |
See also
References
- ^ Which protocols does RabbitMQ support?
- ^ "Launch of RabbitMQ Open Source Enterprise Messaging" (PDF). Press release. February 8, 2007. Retrieved October 23, 2013.
- ^ "Rabbit Technologies announce acquisition by SpringSource". Press release. April 13, 2010. Archived from the original on April 18, 2010. Retrieved October 3, 2013.
- ^ "Proudly part of Pivotal". Press release. May 14, 2010. Archived from the original on June 2, 2013. Retrieved October 3, 2013.
- ^ "VMware Completes Acquisition of Pivotal". VMware News and Stories. Retrieved 2023-04-06.
{{cite web}}
: CS1 maint: url-status (link) - ^ "RabbitMQ". endoflife.date. Retrieved 2023-04-14.
Further reading
- Joern Barthel (2009-09-13). "Getting started with AMQP and RabbitMQ". InfoQ.
- Peter Cooper (2009-04-09). "RabbitMQ - A Fast, Reliable Queuing Option for Rubyists". RubyInside.
- RabbitMQ: An Open Source Messaging Broker That Just Works. Google Tech Talks. 2008-09-25.